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

本文介绍了ActiveRecord中配置信息的构建方法,包括配置项说明及三种配置方式:XML配置、硬编码配置与应用配置文件配置,并提供了针对不同数据库的示例。

摘要: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的文件

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<?xmlversion="1.0"encoding="utf-8"?>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<activerecord>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<config>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<addkey="hibernate.connection.driver_class"value="NHibernate.Driver.SqlClientDriver"/>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<addkey="hibernate.dialect"value="NHibernate.Dialect.MsSql2000Dialect"/>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<addkey="hibernate.connection.provider"value="NHibernate.Connection.DriverConnectionProvider"/>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<addkey="hibernate.connection.connection_string"value="DataSource=.;InitialCatalog=ARDemo;UID=sa;Password=sa"/>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客</config>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客</activerecord>

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

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客XmlConfigurationSourcesource=newXmlConfigurationSource("MyConfig.xml");

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客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配置

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

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客InPlaceConfigurationSourcesource=newInPlaceConfigurationSource();

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客Hashtableproperties=newHashtable();

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客properties.Add("hibernate.connection.driver_class","NHibernate.Driver.SqlClientDriver");

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客properties.Add("hibernate.dialect","NHibernate.Dialect.MsSql2000Dialect");

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客properties.Add("hibernate.connection.provider","NHibernate.Connection.DriverConnectionProvider");

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客properties.Add("hibernate.connection.connection_string","UID=sa;Password=19811218;InitialCatalog=ARDemo;DataSource=.");

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客source.Add(typeof(ActiveRecordBase),properties);

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客ActiveRecordStarter.Initialize(source,typeof(ActiveRecordBase));

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

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

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<?xmlversion="1.0"encoding="utf-8"?>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<configuration>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<configSections>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<sectionname="activerecord"type="Castle.ActiveRecord.Framework.Config.ActiveRecordSectionHandler,Castle.ActiveRecord"/>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客</configSections>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<activerecord>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<config>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<addkey="hibernate.connection.driver_class"value="NHibernate.Driver.SqlClientDriver"/>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<addkey="hibernate.dialect"value="NHibernate.Dialect.MsSql2000Dialect"/>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<addkey="hibernate.connection.provider"value="NHibernate.Connection.DriverConnectionProvider"/>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<addkey="hibernate.connection.connection_string"value="UID=sa;Password=sa;InitialCatalog=ARDemo;DataSource=."/>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客</config>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客</activerecord>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客</configuration>

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

[.NET1.1]

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客IConfigurationSourcesource=System.Configuration.ConfigurationSettings.GetConfig("activerecord")asIConfigurationSource;

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客ActiveRecordStarter.Initialize(source,typeof(ActiveRecordBase));

[.NET2.0]

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客IConfigurationSourcesource=System.Configuration.ConfigurationManager.GetSection("activerecord")asIConfigurationSource;

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客ActiveRecordStarter.Initialize(source,typeof(ActiveRecordBase));

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

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

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<activerecordisWeb="true">

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<config>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<addkey="hibernate.connection.driver_class"value="NHibernate.Driver.SqlClientDriver"/>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<addkey="hibernate.dialect"value="NHibernate.Dialect.MsSql2000Dialect"/>Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<addkey="hibernate.connection.provider"value="NHibernate.Connection.DriverConnectionProvider"/>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<addkey="hibernate.connection.connection_string"value="UID=sa;Password=sa;InitialCatalog=ARDemo;DataSource=."/>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客</config>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客</activerecord>

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

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客protectedvoidApplication_Start(Objectsender,EventArgse)

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客{

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客IConfigurationSourcesource=

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客System.Configuration.ConfigurationSettings.GetConfig("activerecord")asIConfigurationSource;

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客ActiveRecordStarter.Initialize(source,typeof(ActiveRecordBase));

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客}

三.常见的配置示例

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

1.MS SQLServer

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<activerecord>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<config>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<addkey="hibernate.connection.driver_class"value="NHibernate.Driver.SqlClientDriver"/>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<addkey="hibernate.dialect"value="NHibernate.Dialect.MsSql2000Dialect"/>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<addkey="hibernate.connection.provider"value="NHibernate.Connection.DriverConnectionProvider"/>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<addkey="hibernate.connection.connection_string"value="DataSource=.;InitialCatalog=test;UID=sa;Password=sa"/>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客</config>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客</activerecord>

2.Oracle

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<activerecord>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<config>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<addkey="hibernate.connection.driver_class"value="NHibernate.Driver.OracleClientDriver"/>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<addkey="hibernate.dialect"value="NHibernate.Dialect.OracleDialect"/>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<addkey="hibernate.connection.provider"value="NHibernate.Connection.DriverConnectionProvider"/>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<addkey="hibernate.connection.connection_string"value="DataSource=dm;UserID=dm;Password=dm;"/>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客</config>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客</activerecord>

3.MySQL

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<activerecord>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<config>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<addkey="hibernate.connection.driver_class"value="NHibernate.Driver.MySqlDataDriver"/>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<addkey="hibernate.dialect"value="NHibernate.Dialect.MySQLDialect"/>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<addkey="hibernate.connection.provider"value="NHibernate.Connection.DriverConnectionProvider"/>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<addkey="hibernate.connection.connection_string"value="Database=test;DataSource=someip;UserId=blah;Password=blah"/>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客</config>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客</activerecord>

4.Firebird

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<activerecord>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<config>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<addkey="hibernate.connection.driver_class"value="NHibernate.Driver.FirebirdDriver"/>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<addkey="hibernate.dialect"value="NHibernate.Dialect.FirebirdDialect"/>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<addkey="hibernate.connection.provider"value="NHibernate.Connection.DriverConnectionProvider"/>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<addkey="hibernate.connection.connection_string"value="Server=localhost;Database=d:/db.fdb;User=SYSDBA;password=masterkey;ServerType=1;Pooling=false"/>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<addkey="hibernate.query.substitutions"value="true1,false0"/>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客</config>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客</activerecord>

5.PostgreSQL

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<activerecord>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<config>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<addkey="hibernate.connection.driver_class"value="NHibernate.Driver.NpgsqlDriver"/>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<addkey="hibernate.dialect"value="NHibernate.Dialect.PostgreSQLDialect"/>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客<addkey="hibernate.connection.provider"value="NHibernate.Connection.DriverConnectionProvider"/>

<addkey="hibernate.connection.connection_string"value="Server=localhost;initialcatalog=nhibernate;UserID=nhibernate;Password=nhibernate;"/>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客</config>

Castle ActiveRecord学习实践(2):构建配置信息  - 网络一小人物 - 网络一小人物的博客</activerecord>

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值