该文章来自[url=http://terrylee.cnblogs.com]Terrylee[/url]

摘要:ActiveRecord在底层封装了NHibernate,在框架启动时需要指定相关的配置信息,那么我们需要配置些什么?又该如何去配置呢?本文将会介绍在ActiveRecord中构建配置信息。

主要内容

1.需要配置什么

2.如何去配置

3.常见的配置示例

一.需要配置什么

在第一篇大家都已经看到了,其实我们的配置信息跟用NHibernate时的配置是一样的,这是因为ActiveRecord在底层封装了NHibernate。为了没有用过NHibernate的朋友,这里再把配置信息简单介绍一下。

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

2.可选的配置属性

除了上面的ADO.NET属性之外,我们还有如下的可选属性

属性名
说明

hibernate.dialect
NHibernate方言(Dialect)的类名 - 可以让NHibernate使用某些特定的数据库平台的特性

例如: full.classname.of.Dialect(如果方言创建在NHibernate中), 或者full.classname.of.Dialect, assembly (如果使用一个自定义的方言的实现,它不属于NHibernate)。

hibernate.default_schema
在生成的SQL中,scheml/tablespace的全限定名.

例如: SCHEMA_NAME

hibernate.prepare_sql
是否准备sql语句

例如: true | false

hibernate.session_factory_name
SessionFactory被创建后将自动绑定这个名称.

例如: some.name

hibernate.use_outer_join
允许使用外连接抓取。

例如:true | false

hibernate.cache.provider_class
指定一个自定义的CacheProvider缓存提供者的类名

例如: full.classname.of.CacheProvider(如果ICacheProvider创建在NHibernate中), 或full.classname.of.CacheProvider, assembly(如果使用一个自定义的ICacheProvider,它不属于NHibernate)。

hibernate.query.substitutions
把NHibernate查询中的一些短语替换为SQL短语(比如说短语可能是函数或者字符)。

例如: hqlLiteral=SQL_LITERAL, hqlFunction=SQLFUNC

可以数据库设置一个hibernate.dialect方言,它是NHibernate.Dialect.Dialect 的一个子类。如果不需要使用基于native或者sequence的主键自动生成算法,或者悲观锁定(使用ISession.Lock() 或者 IQuery.SetLockMode())的话,方言就可以不必指定。然而,假若你指定了一个方言,Hibernate会为上面列出的一些属性使用特殊默认值,省得我们手工指定。

NHibernate SQL 方言对照表:

数据库系统
SQL方言

DB2
NHibernate.Dialect.DB2Dialect

PostgreSQL
NHibernate.Dialect.PostgreSQLDialect

MySQL
NHibernate.Dialect.MySQLDialect

Oracle (any version)
NHibernate.Dialect.OracleDialect

Oracle 9/10g
NHibernate.Dialect.Oracle9Dialect

Sybase
NHibernate.Dialect.SybaseDialect

Microsoft SQL Server 2000
NHibernate.Dialect.MsSql2000Dialect

Microsoft SQL Server 7
NHibernate.Dialect.MsSql7Dialect

Firebird
NHibernate.Dialect.FirebirdDialect

二.如何去配置

ActiveRecord为我们提供了三种方式的配置

1.XmlConfigurationSource配置

可以使用自己的XML文件来保存配置信息,例如有一个MyConfig.xml的文件

<?xml version="1.0" encoding="utf-8" ?>

<activerecord>

<config>

<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="Data Source=.;Initial Catalog=ARDemo;UID=sa;Password=sa" />

</config>

</activerecord>
这时候我们在框架初始化的时候就应该这样写:

XmlConfigurationSource source = new XmlConfigurationSource("MyConfig.xml");

ActiveRecordStarter.Initialize(source,typeof(ActiveRecordBase));
其中XmlConfigurationSource通过重载提供了如下三个公用的构造函数

public XmlConfigurationSource(String xmlFileName)

public XmlConfigurationSource(Stream stream)

public XmlConfigurationSource(TextReader reader)

不管是以文件名还是Stream形式或者TextReader,在XmlConfigurationSource的内部都会转换为XmlDocument。最后要注意xml文件的路径,可以用生成后事件命令拷贝.xml文件到bin目录下

copy "$(ProjectDir)\*.xml" "$(TargetDir)"

2.InPlaceConfigurationSource配置

这种实现是一种硬编码的方式,在实际的使用中并不推荐,但是有时候如果我们的配置信息是动态的获取,则这种方式就会变得非常有用。

InPlaceConfigurationSource source = new InPlaceConfigurationSource();

Hashtable properties = new Hashtable();

properties.Add("hibernate.connection.driver_class", "NHibernate.Driver.SqlClientDriver");

properties.Add("hibernate.dialect", "NHibernate.Dialect.MsSql2000Dialect");

properties.Add("hibernate.connection.provider", "NHibernate.Connection.DriverConnectionProvider");

properties.Add("hibernate.connection.connection_string", "UID=sa;Password=19811218;Initial Catalog=ARDemo;Data Source=.");

source.Add( typeof(ActiveRecordBase), properties );

ActiveRecordStarter.Initialize( source, typeof(ActiveRecordBase) );

3.使用应用程序配置文件

这种方式是最为常见的一种,即使用应用程序的配置文件(Web.config 或者App.config),在配置文件中

<?xml version="1.0" encoding="utf-8" ?>

<configuration>

<configSections>

<section name="activerecord" type="Castle.ActiveRecord.Framework.Config.ActiveRecordSectionHandler, Castle.ActiveRecord" />

</configSections>

<activerecord>

<config>

<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="UID=sa;Password=sa;Initial Catalog=ARDemo;Data Source=." />

</config>

</activerecord>

</configuration>

这时候我们的框架初始化代码应该这样写

[.NET1.1]

IConfigurationSource source = System.Configuration.ConfigurationSettings.GetConfig("activerecord") as IConfigurationSource;

ActiveRecordStarter.Initialize( source, typeof(ActiveRecordBase) );

[.NET2.0]

IConfigurationSource source = System.Configuration. ConfigurationManager.GetSection ("activerecord") as IConfigurationSource;

ActiveRecordStarter.Initialize( source, typeof(ActiveRecordBase) );

4.在Web应用程序中的配置

如果我们是在Web应用程序中使用ActiveRecord,需要指定isWeb="true",如下

<activerecord isWeb="true">

<config>

<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="UID=sa;Password=sa;Initial Catalog=ARDemo;Data Source=." />

</config>

</activerecord>

一般的初始化工作我们会放在Application_ Start中,示例代码

protected void Application_Start(Object sender, EventArgs e)

{

IConfigurationSource source =

System.Configuration.ConfigurationSettings.GetConfig("activerecord") as IConfigurationSource;

ActiveRecordStarter.Initialize( source, typeof(ActiveRecordBase));

}

三.常见的配置示例

Castle网站为我们提供的几个常见的配置示例
1.MS SQLServer

<activerecord>

<config>

<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="Data Source=.;Initial Catalog=test;UID=sa;Password=sa" />

</config>

</activerecord>

2.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>

3.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>

4.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>

5.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>

关于ActiveRecord构建配置信息的介绍就这么多了,内容比较简单。下篇文章中我会详细介绍ActiveRecord中的映射,希望研究过Castle的朋友不吝赐教。

参考资料

Castle的官方网站http://www.castleproject.org/

转载于:https://www.cnblogs.com/lhg0302/articles/1032221.html

Castle ActiveRecord学习实践:构建配置信息相关推荐

  1. Castle ActiveRecord学习实践(2):构建配置信息

    摘要:ActiveRecord在底层封装了NHibernate,在框架启动时需要指定相关的配置信息,那么我们需要配置些什么?又该如何去配置呢?本文将会介绍在ActiveRecord中构建配置信息. 主 ...

  2. Castle ActiveRecord学习实践(1):快速入门指南

    摘要:最近几天有时间看了一下Castle,原来它的功能是如此的强大,从数据访问框架到IOC容器,再到WEB框架,基本包括了整个开发过程中的所有东西,看来得好好学习研究一下了,并且打算把自己学习过程的一 ...

  3. Castle ActiveRecord学习实践(4):实现One-Many关系的映射

    摘要:前面几篇文章简单的介绍了ActiveRecord中的基本映射以及构建配置信息,本文我们用ActiveRecord里面的Blog,Post例子来实现One-Many/Many-One关联. 主要内 ...

  4. Castle ActiveRecord学习实践(8)HQL查询

    本篇来了解下Castle ActiveRecord hql 查询语句. 博客园中讲解Castle ActiveRecord 的文章已经很多了,博主就不自己写了.转载一篇TerryLee大大的文章. 摘 ...

  5. Castle ActiveRecord学习实践(5):实现Many–Many关系的映射

    摘要:多对多的关系在日常开发中也会经常遇到,在ActiveRecord中我们用HasAndBelongsToMany特性来实现Many-Many的关联,本文将通过一个具体的实例来介绍这一用法. 主要内 ...

  6. Castle ActiveRecord学习实践(6):延迟加载和使用Where子句

    摘要:在ActiveRecord中把数据库表之间的关联关系采用对象间的聚合关系来表现,然而这却带来一系列的性能上的问题.就像我在One-Many中用到的例子Blog,使用Blog.Find(1)查找了 ...

  7. Castle ActiveRecord学习实践(7):使用HQL查询

    摘要:虽然ActiveRecord为我们提供了Find()和FindAll()这样两个静态的查询方法,并且有Where特性可供使用,但是仍然不能解决实际开发中一些复杂的查询,这时我们就需要通过HQL查 ...

  8. Castle ActiveRecord学习笔记四:各种映射

    这里主要来说明ActiveRecord的属性与数据库及其字段的对应关系. 主要以ActiveRecordAttribute.PrimaryKeyAttribute.PropertyAttribute来 ...

  9. Nagios学习实践系列——配置研究[监控当前服务器]

    其实上篇Nagios学习实践系列--基本安装篇只是安装了Nagios基本组件,虽然能够打开主页,但是如果不配置相关配置文件文件,那么左边菜单很多页面都打不开,相当于只是一个空壳子.接下来,我们来学习研 ...

  10. Castle ActiveRecord学习(四)延迟加载、分页查询、where条件

    一.延迟加载 //用户发布的主题,一对多:Table:外键表:ColumnKey:外键:Lazy:延迟加载:Cascade:级联操作(级联删除)[HasMany(typeof(ThemeInfo), ...

最新文章

  1. http://www.jikexueyuan.com/course/181.html
  2. [分享] 数学学术资源站点
  3. python网页服务器_python编写简单网页服务器
  4. vue中渲染对象中属性时显示未定义_揭开 vue 背后的秘密(1)
  5. DC/DC开关电源设计
  6. 栈与队列在SGI STL的底层实现
  7. 如何通过序列化在网络间传递对象,网络协议:轻松定义自己的网络通讯协议
  8. 2017.7.10 Redis报错:DENIED Redis is running in protected mode
  9. 打印Fibonacci数列方法汇总(前20项,每行5个)
  10. 2013/7/16 HNU_训练赛4
  11. C语言的数组简单复习
  12. 用gambit学博弈论--完全信息动态博弈-博弈扩展式、博弈树(二)
  13. 传奇人物称号设置详细步骤
  14. Windows 7 修改系统临时文件夹
  15. 聊天机器人之知识图谱 Freebase 简介
  16. 淘宝天猫自动领取喵币
  17. 【PhD Debate - 14】将科幻照进现实——元宇宙数字人的当下与未来
  18. 输入一个整数,判断是偶数还是奇数
  19. java程序 购物车_用java代码写一个简单的网上购物车程序
  20. 计算机操作培训图片,【图片】计算机学习之旅【汇编吧】_百度贴吧

热门文章

  1. BZOJ2431:[HAOI2009]逆序对数列(DP,差分)
  2. hadoop搭建和指令
  3. GAN 生成mnist数据
  4. WPF入门教程系列二十——ListView示例(二)
  5. 分布式游戏网关--fooking
  6. arm linux 优化
  7. Kotlin基本类型
  8. NE40E面板ALM报警亮灯
  9. python笔记23-unittest单元测试之mock
  10. 《Java技术》第四次作业