说明:本系列文章参考自李会军先生的Castle 开发系列文章,而后记录本身在学习时遇到的一些问题,记录之。html
主要内容web
一、Castle配置学习数据库
二、初始化配置app
Castle配置学习ide
<?xml version="1.0"?>
<configuration>
<configSections>
<section name="activerecord" type="Castle.ActiveRecord.Framework.Config.ActiveRecordSectionHandler, Castle.ActiveRecord"/>
</configSections>
<activerecord>
<config>
<add key="connection.driver_class" value="NHibernate.Driver.SqlClientDriver" />
<add key="dialect" value="NHibernate.Dialect.MsSql2008Dialect" />
<add key="connection.provider" value="NHibernate.Connection.DriverConnectionProvider" />
<add key="proxyfactory.factory_class" value="NHibernate.ByteCode.Castle.ProxyFactoryFactory, NHibernate.ByteCode.Castle" />
<add key="connection.connection_string" value="Data Source=localhost;Initial Catalog=Study;User ID=sa;Password=******" />
</config>
</activerecord>
<system.web>
<compilation debug="true"/>
</system.web>
</configuration>
此段配置适用于配置其NHibernate ADO.NET的。学习
a、activerecord代表自定义节点,其类型(type)代表了ActiveRecord的实现程序集和命名空间。编码
b、connection.driver_class,定制IDriver
的类型,能够配置适用于不一样类型数据库的驱动。spa
c、connection.provider,配置链接驱动提供程序。debug
d、dialect,用于配置NHibernate的方言环境,能够经过此配置使用数据库的某些特性。代理
e、proxyfactory.factory_class,新版本Castle须要添加此配置,用来配置代理工厂的工厂类。
f、connection.connection_string,用来配置数据链接字符串。
初始化配置
一、经过配置文件
//获取web.config或者app.config中相应的配置信息
IConfigurationSource cfgSrc = System.Configuration.ConfigurationManager.GetSection("activerecord") as IConfigurationSource;
//初始化ActiveRecord ActiveRecordStarter.Initialize(cfgSrc, typeof(User));
二、经过硬编码
InPlaceConfigurationSource source = new InPlaceConfigurationSource();
Hashtable properties = new Hashtable();
properties.Add("connection.driver_class", "NHibernate.Driver.SqlClientDriver");
properties.Add("dialect", "NHibernate.Dialect.MsSql2000Dialect");
properties.Add("connection.provider", "NHibernate.Connection.DriverConnectionProvider");
properties.Add("proxyfactory.factory_class", "NHibernate.ByteCode.Castle.ProxyFactoryFactory, NHibernate.ByteCode.Castle");
properties.Add("connection.connection_string", "Data Source=localhost;Initial Catalog=Study;User ID=sa;Password=******");
source.Add(typeof(ActiveRecordBase), properties);
ActiveRecordStarter.Initialize(source, typeof(ActiveRecordBase));
注意:
一、对于不一样类型的数据库咱们只需更改dialect和connection.connection_string字节信息便可
二、经常使用的dialect
MySQL |
|
Oracle (any version) |
|
Oracle 9/10g |
|
Sybase |
|
Microsoft SQL Server 2000 |
|
再次说明:本系列文章参考自李会军先生的Castle 开发系列文章,而后记录本身在学习时遇到的一些问题,记录之。