NHibernate Configuring
NHibernate引用程序中有几个关键组件,如下图所示:

初始化时,NHibernate应用程序将生成一个配置对象。本节中,我们通过设置App.config文件来生成该配置对象。该对象负责加载映射信息、反射模型的其他信息 、生成映射的元数据并最终生成一个会话工厂。生成一个会话工厂的开销是昂贵的,因此在一个应用程序的生命周期中只构建一次。该会话工厂负责生成会话。和生成会话工厂不同,生成一个会话的开销是很小的。
在应用程序中,一个会话代表一个工作单元。马丁·福勒将一个工作单元定义为一个对象(该对象包含业务与coordinates相关的对象的列表)和the writing out of changes 和并发性问题的解决方案。NHibernate会话会跟踪实体的变化,并根据这些变化统一更新数据库。在NHibernate中,这种先等待后统一更新数据库的处理方法被称为延迟事务处理。另外,该会话是大部分NHibernate API的入口。
工作单元模式的更多信息请参看http://martinfowler.com/eaaCatalog/unitOfWork.html和马丁·福勒的著作《Patterns of Enterprise Application Architecture》.
该会话充当了应用程序和几个关键NHibernate组件的媒介。也就是说应用程序将不会直接与这些组件交互,但是理解这些组件将是理解NHibernate的关键。 dialect用来生成符合特定的RDBMS的语法的SQL语句。例如,在Microsoft SQL Server中, SELECT TOP 20这个语句会生成结果集中的前20条记录,也就是只有20条记录返回。但是在SQLite中,还要在该语句的末尾加上LIMIT 20. 每一个dialect都为所选定的RDBMS提供必要的SQL语法转换和其他信息以确保可以生成正确的SQL语句. driver负责生成batcher、创建IDbConnection和IDbCommand对象,以及准备这些指令.
connection provider只负责打开关闭数据库连接. batcher负责管理发送给数据库/数据读取器结果集的批处理。目前只有和SqlClientDriver和OracleDataDriver支持该功能 。不支持该功能的drivers使用NonBatchingBatcher管理 IDbCommands和IDataReaders,她可以模拟实现单一的批处理(逻辑上的)功能.
NHibernate 属性列表
下表是几个常用的NHibernate属性.
| 属性名 | 描述 |
| connection.provider | 打开关闭数据库连接 |
| connection.driver_class | 由所使用的RDBMS确定,通常由dialect自动设置。 |
| connection.connection_string |
数据库连接字符串
|
| connection.connection_string_name |
数据库连接字符串名称(定义在.Net配置文件<connectionStrings>配置节里面的连接字符串名。
|
| connection.isolation |
ADO.NET事务隔离级别
|
| dialect | 必须配置。生成特定于RDBMS的SQL. NHibernate.Dialect 命名空间下有许多可选的dialect |
| show_sql | Boolean值.设置为true时输入所有SQL语句到控制台或者使用log4net将SQL语句输出倒其他位置 |
| current_session_context_class | 管理上下文相关的会话的一个类,将在第三章进一步阐述 |
| query.substitutions | 将执行的查询字符串替换为用逗号分割的列表,例如True=1, Yes=1, False=0, No=0. |
| sql_exception_converter | 将特定数据库的ADO.NET异常转化为自定义的异常 |
| prepare_sql | Boolean值. 准备SQL语句和缓存持续数据库连接的执行计划。 |
| command_timeout | Nhibernate等待完成一个SQL命令的超时时间:单位:秒。 |
| adonet.batch_size | 指定用ADO.Net的批量更新的数量,默认设置为0(不启用该功能)。 |
| generate_statistics | 启用对统计信息的跟踪,例如多少个查询被执行,多少个实体被加载。 |
| proxyfactory.factory_class | 必须配置.为所选的代理框架指定一个工厂类,本节使用:Castle DynamicProxy2. |
| format_sql | 添加行结束标记以增强SQL语句的可读性 |
关于这些设置的详细信息请参考:http://www.nhforge.org/doc/nh/en/index.html .
Dialects and drivers
大多数情况下,dialects设置完以后可以为部分的NHibernate属性提供默认值,比如connection.driver_class。NHibernate的NHibernate.Dialect namespace和NHibernate.Driver namespace中的dialects和drivers见下表:
| RDBMS | Dialect(s) | Driver(s) |
| Microsoft SQL Server | MsSql2008Dialect | SqlClientDriver |
| MsSql2005Dialect | SqlServerCEDriver | |
| MsSql2000Dialect | ||
| MsSql7Dialect | ||
| MsSqlCEDialect | ||
| Oracle | Oracle10gDialect | OracleClientDriver |
| Oracle9iDialect | OracleDataClientDriver | |
| Oracle8iDialect | OracleLiteDataDriver | |
| OracleLiteDialect | ||
| MySql | MySQLDialect | MySqlDataDriver |
| MySQL5Dialect | ||
| PostgreSQL | PostGreSQLDialect | NpgsqlDriver |
| PostGreSQL81Dialect | ||
| PostGreSQL82Dialect | ||
| DB2 | DB2Dialect | DB2Driver |
| Db2400Dialect | DB2400Driver | |
| Informix | InformixDialect | IfxDriver |
| InformixDialect0940 | ||
| InformixDialect1000 | ||
| Sybase | SybaseDialect | SybaseClientDriver |
| SybaseASA10Dialect | ASAClientDriver | |
| SybaseASA9Dialect | ASA10ClientDriver | |
| Sybase11Dialect | SybaseAdoNet12ClientDriver | |
| SybaseAdoNet12Dialect | ||
| SybaseAnywhereDialect | ||
| Firebird | FirebirdDialect | FirebirdDriver |
| FirebirdClientDriver | ||
| SQLite | SQLiteDialect | SQLiteDriver |
| SQLite20Driver | ||
| Ingres | IngresDialect | IngresDriver |
NHibernate Configuring的更多相关文章
- NHibernate的调试技巧和Log4Net配置
1.查看nhibernate写在控制台里的sql语句 在配置文件中有这么个选项,假如把它设置为true,nhibernate会把执行的sql显示在控制台上. <property name=&qu ...
- Nhibernate的Session管理
参考:http://www.cnblogs.com/renrenqq/archive/2006/08/04/467688.html 但这个方法还不能解决Session缓存问题,由于创建Session需 ...
- "NHibernate.Exceptions.GenericADOException: could not load an entity" 解决方案
今天,测试一个项目的时候,抛出了这个莫名其妙的异常,然后就开始了一天的调试之旅... 花了很长时间,没有从代码找出任何问题... 那么到底哪里出问题呢? 根据下面那段长长的错误日志: -- ::, ...
- nhibernate连接11g数据库
我框架的数据映射用 nhibernate连接多数据库,这次又增加了oracle11g,负责开发的同事始终连接不上,悲催的sharepoint调试是在不方便... 下面描述下问题的解决,细节问题有3个: ...
- 全自动迁移数据库的实现 (Fluent NHibernate, Entity Framework Core)
在开发涉及到数据库的程序时,常会遇到一开始设计的结构不能满足需求需要再添加新字段或新表的情况,这时就需要进行数据库迁移. 实现数据库迁移有很多种办法,从手动管理各个版本的ddl脚本,到实现自己的mig ...
- 跟我学习NHibernate (1)
引言:Nibernate概述 NHibernate是一个ORM框架,NHibernate是一个把C#对象世界和关系世界数据库之间联系起来的一座桥梁.NHibernate 能自动映射实体模型到数据库,所 ...
- 让OData和NHibernate结合进行动态查询
OData是一个非常灵活的RESTful API,如果要做出强大的查询API,那么OData就强烈推荐了.http://www.odata.org/ OData的特点就是可以根据传入参数动态生成Ent ...
- MVC Nhibernate 示例
首先,非常感谢提出问题的朋友们,使得本人又去深入研究了NHibernate的<Session-Per-Request 模式>. 前言: 谈到NHibernate大伙并不陌生,搞Java ...
- Nhibernate mapping 文件编写
生成工具软件 现在生成工具软件有很多了,例如商业软件:NMG.CodeSmith.Visual NHibernate,开源软件:MyGeneration.NHibernate Modeller.AjG ...
随机推荐
- windows 10开启bash on windows,配置sshd,部署hadoop
1.安装Bash on Windows 这个参考官网步骤,很容易安装,https://msdn.microsoft.com/en-us/commandline/wsl/install_guide 安装 ...
- nginx 服务器篇
Nginx 服务器类型 1. Web服务器 Web服务器用于提供HTTP(包括HTTPS)的访问,例如Nginx.Apache.IIS等. 2. 应用程序服务器 应用程序服务器能够用于应用程序的运行, ...
- web项目更改文件后缀,隐藏编程语言
从Java EE5.0开始,<servlet-mapping>标签就可以配置多个<url-pattern>.例如可以同时将urlServlet配置一下多个映射方式: <s ...
- java通过jdbc插入中文到mysql显示异常(问号或者乱码)
转自:https://blog.csdn.net/lsr40/article/details/78736855 首先本人菜鸡一个,如果有说错的地方,还请大家指出予批评 对于很多初学者来说,中文字符编码 ...
- C++的一大误区——深入解释直接初始化与复制初始化的区别
转自:http://blog.csdn.net/ljianhui/article/details/9245661 不久前,在博客上发表了一篇文章——提高程序运行效率的10个简单方法,对于其中最后一 ...
- jquery li a 样式
jQuery(".CwebtopNavContainer").find("li:last a").css("color","red ...
- Download Percona Monitoring Plugins
https://www.percona.com/downloads/percona-monitoring-plugins/LATEST/
- 专题-Delphi/C++ Builder多线程编程与调试
[目录] Delphi.C++ Builder多线程程序编码调试的一点经验谈 多线程程序的填坑笔记和多线程编程应该遵循的规则(天地弦) 多线程编程中死锁问题的跟踪与解决 临界.多重读独占写多线程同步测 ...
- SQL Server Connection Pooling (ADO.NET)
SQL Server Connection Pooling (ADO.NET) Connecting to a database server typically consists of severa ...
- C#中泛型的使用
1. List<T> 2. Dictionary<TKey, TValue> 命名空间:using System.Collections.Generic; 普通数组:在声明时必 ...