3

有时我真的开始想知道我的源代码中发生了什么:我正在尝试使用 npgsql 2.0.11.0 连接到 PostGres 9.0,我很确定我已经这样做了,但是现在,我的程序在进入时抛出了NotSupportedException以下 :

ISessionFactory sf = Fluently.Configure()
                        .Database(PostgreSQLConfiguration.PostgreSQL82
                        .ConnectionString(c => c
                        .Host("localhost")
                        .Port(5432)
                        .Database("cw")
                        .Username("cw")
                        .Password("mypass")))
                        .Mappings(x => x.FluentMappings.AddFromAssemblyOf<MyMapping>())
                        .BuildSessionFactory();

Stacktrace 看起来非常整洁:只有一行。

at NHibernate.Dialect.Dialect.GetDataBaseSchema(DbConnection connection) in d:\CSharp\NH\nhibernate\src\NHibernate\Dialect\Dialect.cs:Line 718.

我尝试将其转录为以下内容:

ISessionFactory sf = Fluently.Configure()
                        .Database(PostgreSQLConfiguration.PostgreSQL82
                        .ConnectionString(c => c.Is("Server=localhost;Port=5432;Database=cw;User Id=cw;Password=myPass;")))
                        .Mappings(x => x.FluentMappings.AddFromAssemblyOf<CardTemplateMapping>())
                        .BuildSessionFactory();

不过,结果是一样的。任何人都有类似的问题,或者 - 甚至更好 - 修复?

4

2 回答 2

5

我想我最终会保持自我回答问题最多的记录。

它需要将 hbm2ddl.keywords 属性设置为 none。现在它就像一个魅力。干杯!

 .Database(PostgreSQLConfiguration.PostgreSQL82
                        .Raw("hbm2ddl.keywords","none"));
于 2011-04-03T21:01:14.777 回答
4

看到您已经找到了解决方案。所以只是为了一些背景:

“none”将禁用有关 RDBMS 关键字的任何操作。

关键字适用于 MsSQL、Oracle、Firebird、MsSqlCe、MySQL、SQLite、SybaseAnywhere。

由于 Postgress 不在列表中,因此必须将其设置为 None。

这里有一些信息:Quoting column names with NHibernate and PostgreSQL

于 2011-04-03T21:12:14.613 回答