NHibernate - SchemaExport,SchemaUpdate没有创建数据库/模式

时间:2016-05-18 22:02:34

标签: c# nhibernate fluent-nhibernate

我是NHibernate和Fluent NHibernate的新手。我想要实现的是选择适当的数据库提供程序并单击按钮,生成数据库(如果不存在)并创建所有表,关系等。

在上述开头我遇到了一个问题。即,以下代码不创建数据库 - 作为返回我收到错误。 同样的情况是NHibernate与xml和Fluent NHibernate。 如果我手动创建数据库,代码工作正常,则会创建表。但如果它不存在,不是。

这是NHibernate和xml方法:

<?xml version="1.0" encoding="utf-8" ?>
<hibernate-configuration xmlns="urn:nhibernate-configuration-2.2">
  <session-factory>
    <property name="connection.provider">NHibernate.Connection.DriverConnectionProvider</property>
    <property name="dialect">NHibernate.Dialect.MsSql2012Dialect</property>
    <property name="connection.driver_class">NHibernate.Driver.Sql2012ClientDriver</property>
    <property name="connection.connection_string">Server=.\SQLEXPRESS;Database=databaseName;Initial Catalog=databaseName;User id=user;password=xxx</property>
    <property name="show_sql">true</property>
    <property name="hbm2ddl.auto">create</property>
  </session-factory>
</hibernate-configuration>

这是流利的NHibernate方法:

_sessionFactory = Fluently.Configure()
                        .Database(MsSqlConfiguration.MsSql2012
                        .ConnectionString(@"Server=.\SQLEXPRESS;Database=databaseName;Initial Catalog=databaseName;User id=user;password=xxx")
                        .ShowSql())
                        .Mappings(m => m.FluentMappings.AddFromAssemblyOf<Entry>())
                        .ExposeConfiguration(cfg => new SchemaExport(cfg).Create(true, true)) 
                        .BuildSessionFactory();

所有评论的方法(SchemaUpdate和添加属性)都没有给出任何积极的结果。我仍然收到以下错误:

Cannot open database "databaseName" requested by the login. The login failed.Login failed for user 'user'.

我在Visual Studio 2015中尝试过MSSQL Express 2012和localdb。 我知道最后我应该使用SchemaUpdate来不丢失数据,但是对于开发我可以使用任何尝试过的方法。

我希望有可能在此解决方案中支持以下数据库: MSSQL,Oracle,MySQL,PostgreSQL。

请告知我做错了什么。 感谢。

1 个答案:

答案 0 :(得分:1)

SchemaExport不会创建数据库。它只创建表和其他数据库对象。

创建数据库通常非常耗费配置,需要更多权限。这可能是它从未作为SchemaExport的一部分实现的原因。