zoukankan      html  css  js  c++  java
  • (z)NHibernate配置文件(z)

    有三种方式来存放nhibernate配置

    1, 作为单独的一节放在相应程序的配置文件中,对于执行文件或类库为文件名称后加.config,对于asp.net则是放在web.config中。这种方式必须在配置文件的configSetions中声明nhibernate的配置节,
    配置内容由Cfg.Environment类来读取,该类所有成员均为静态的,另外它还定义了配置中key值的常数。

    2. 放在一个单独的配置文件中,默认为hibernate.cfg.xml,使用时必须调用Cfg.Configuration.Config()。如不是默认的配置文件名,还必须指明配置文件名称。这种方式最适合多数据库的情况,可以为每个数据库建立一个配置文件。

    3. 手工在程序中加入,配置内容最后将加入到Cfg.Configuration.Properties属性中,此属性为一IDictionary对象,并且为public,其余的就不用多话了吧。

    下面对几个重要的key值说明一下:

    hibernate.connection.provider
    连接提供者,取值必须是实现了IConnectionProvider接口的类的全名,当前版本只能取值NHibernate.Connection.DriverConnectionProvider;
    hibernate.connection.driver_class
    数据驱动类,取值必须是实现了IDriver接口的类的全名,常用的选择有NHibernate.Driver.SqlClientDriver, NHibernate.Driver.OleDbDriver等;
    hibernate.dialect
    数据库方言,取值必须是继承之Dialect的类的全名,最常用的就是NHibernate.Dialect.MsSql2000Dialect了, 其它的没用过,不清楚能不能正常使用;
    hibernate.connection.connection_string
    连接字符串,取值与driver_class对应即可;
    hibernate.show_sql
    指明是否在log4net日志中显示sql语句,主要用于调试,取值为true或false;

    完整的配置key列表请查看Cfg.Environment类中的常数声明。

    持久对象映射文件

    nhibernate为我们提供了很多方式将持久对象映射文件加入到Cfg.Configuration类,下面将其一一列出:

    AddXmlFile:加入包括对象映射信息的文件;
    AddXmlString:加入包含映射信息的字符串;
    AddDocument:加入包含映射信息的Xmldocument;
    AddInputStream:加入包含映射信息的输入流;
    AddXmlReader:加入包含映射信息的XmlReader;
    AddResource:加入指定程序集的映射信息资源;
    AddClass:加入以类名指定的映射信息资源,映射文件必须为classname.hbm.xml;
    AddAssembly:加入指定程序集名称的映射信息资源

    注意:如果映射信息为文件形式,包括加入到程序集资源的文件,那么文件名必须以.hbm.xml结尾。

    MS Access 数据库连接配置:

     <add key="hibernate.connection.provider" value="NHibernate.Connection.DriverConnectionProvider" />  
    <add key="hibernate.dialect" value="NHibernate.JetDriver.JetDialect, NHibernate.JetDriver" />  
    <add key="hibernate.connection.driver_class" value="NHibernate.JetDriver.JetDriver, NHibernate.JetDriver" />  
    <add key="hibernate.connection.connection_string" value="Provider=Microsoft.Jet.OLEDB.4.0;Data Source=data.mdb" />

    MS SQL Server 2000 数据库连接配置:

    < add  key ="hibernate.connection.driver_class"  value ="NHibernate.Driver.SqlClientDriver"   />
    < add  key ="hibernate.dialect"                  value ="NHibernate.Dialect.MsSql2000Dialect"   />
    < add  key ="hibernate.connection.provider"      value ="NHibernate.Connection.DriverConnectionProvider"   />
    < add  key ="hibernate.connection.connection_string"  value ="Server=127.0.0.1;UID=sa;Password=***;Initial Catalog=test;Data Source=."   />

    Oracle 数据库连接配置:

    <activerecord>
        
    <config>
            
    <add key="hibernate.connection.driver_class" value="NHibernate.Driver.OracleClientDriver" />
            
    <add key="hibernate.dialect" value="NHibernate.Dialect.OracleDialect" />
            
    <add key="hibernate.connection.provider" value="NHibernate.Connection.DriverConnectionProvider" />
            
    <add key="hibernate.connection.connection_string" value="Data Source=dm;User ID=dm;Password=dm;" />
        
    </config>
    </activerecord>

    MySQL 数据库连接配置:

    <activerecord>
        
    <config>
            
    <add key="hibernate.connection.driver_class" value="NHibernate.Driver.MySqlDataDriver" />
            
    <add key="hibernate.dialect" value="NHibernate.Dialect.MySQLDialect" />
            
    <add key="hibernate.connection.provider" value="NHibernate.Connection.DriverConnectionProvider" />
            
    <add key="hibernate.connection.connection_string" value="Database=test;Data Source=someip;User Id=blah;Password=blah" />
        
    </config>
    </activerecord>

    FireBird 数据库连接配置:

    <activerecord>
        
    <config>
            
    <add key="hibernate.connection.driver_class" value="NHibernate.Driver.FirebirdDriver" />
            
    <add key="hibernate.dialect" value="NHibernate.Dialect.FirebirdDialect" />
            
    <add key="hibernate.connection.provider" value="NHibernate.Connection.DriverConnectionProvider" />
            
    <add key="hibernate.connection.connection_string" value="Server=localhost;Database=d:\db.fdb;User=SYSDBA;password=masterkey;ServerType=1;Pooling=false" />
            
    <add key="hibernate.query.substitutions" value="true 1, false 0" />
        
    </config>
    </activerecord>

    PostgreSQL 数据库连接配置:

    <activerecord>
        
    <config>
            
    <add key="hibernate.connection.driver_class" value="NHibernate.Driver.NpgsqlDriver" />
            
    <add key="hibernate.dialect" value="NHibernate.Dialect.PostgreSQLDialect" />
            
    <add key="hibernate.connection.provider" value="NHibernate.Connection.DriverConnectionProvider" />
            
    <add key="hibernate.connection.connection_string" value="Server=localhost;initial catalog=nhibernate;User ID=nhibernate;Password=nhibernate;" />
        
    </config>
    </activerecord>


  • 相关阅读:
    重写移动端滚动条[iScroll.js核心代码]
    利用canvas将网页元素生成图片并保存在本地
    微信小程序的拖拽、缩放和旋转手势
    设计模式之访问者(visitor)模式
    设计模式之原型(prototype)模式
    设计模式之享元(flyweight)模式
    设计模式之职责链模式
    设计模式之组合(compose)模式
    leetcode16
    校招真题练习013 找零(头条)
  • 原文地址:https://www.cnblogs.com/Luouy/p/1378773.html
Copyright © 2011-2022 走看看