另一种方法就是,你可以让ISessionFactory替你打开连接。SessionFactory必须事先知道ADO.NET连接的参数,有几种不同的方法设置参数:
- 通过提供一个IDictionary实例给Configuration.Properties。
- 在名为nhibernate的System.Configuration.NameValueSectionHandler类型的配置节点添加属性。
- 在hibernate.cfg.xml 中包含元素。
如果你使用这种方法,打开一个ISession是非常简单的:
ISession session = sessions.OpenSession(); // open a new Session
// do some data access work, an ADO connection will be used on demand
所有的NHibernate属性名和约束都在 NHibernate.Cfg.Environment类中定义。我们讨论一下ADO.NET连接配置最重要的几项设置:
假若你设置了如下的属性,NHibernate会使用ADO.NET Data Provider来得到连接:
表2.1 NHibernate ADO.NET 属性| 属性名 | 用途 |
|---|
| hibernate.connection.provider_class | 定制IConnectionProvider的类型. 例如:full.classname.of.ConnectionProvider (如果提供者创建在NHibernate中), 或者 full.classname.of.ConnectionProvider, assembly (如果使用一个自定义的IConnectionProvider接口的实现,它不属于NHibernate)。 |
| hibernate.connection.driver_class | 定制IDriver的类型. full.classname.of.Driver (如果驱动类创建在NHibernate中), 或者 full.classname.of.Driver, assembly (如果使用一个自定义IDriver接口的实现,它不属于NHibernate)。 |
| hibernate.connection.connection_string | 用来获得连接的连接字符串. |
| hibernate.connection.isolation | 设置事务隔离级别. 请检查 System.Data.IsolationLevel 来得到取值的具体意义并且查看数据库文档以确保级别是被支持的。 例如: Chaos, ReadCommitted, ReadUncommitted, RepeatableRead, Serializable, Unspecified |
下面是一个在web.config文件中指定连接属性的例子:
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<configSections>
<section name="nhibernate" type="System.Configuration.NameValueSectionHandler, System,
Version=1.0.5000.0,Culture=neutral, PublicKeyToken=b77a5c561934e089" />
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net" />
</configSections>
<nhibernate>
<add
key="hibernate.connection.provider"
value="NHibernate.Connection.DriverConnectionProvider"
/>
<add
key="hibernate.connection.driver_class"
value="NHibernate.Driver.SqlClientDriver"
/>
<add
key="hibernate.connection.connection_string"
value="Server=127.0.0.1;Initial Catalog=thedatabase;Integrated Security=SSPI"
/>
<add
key="hibernate.connection.isolation"
value="ReadCommitted"
/>
<add
key="hibernate.dialect"
value="NHibernate.Dialect.MsSql2000Dialect"
/>
</nhibernate>
<!-- log4net (required by NHibernate) and other app specific config follows -->
</configuration>
顶部