ActiveRecord 的多数据库配置基本沿袭了 NHibernate 的思想,只不过在配置文件结构上作了些调整。
1. 采用继承方式,归纳使用同一数据库的类型。比如 A、B、C、D、E 中 A、B连接到数据库Test1,C、D连接到Test2,而E连接到缺省的Test,那么具体的代码就会是下面这种方式。

public abstract class Test1Base : ActiveRecordBase
{
} public abstract class Test2Base : ActiveRecordBase
{
} [ActiveRecord("A")]
public class A : Test1Base
{
} [ActiveRecord("B")]
public class B : Test1Base
{
} [ActiveRecord("C")]
public class C : Test2Base
{
} [ActiveRecord("D")]
public class D : Test2Base
{
} [ActiveRecord("E")]
public class E : ActiveRecordBase
{
}

config.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=localhost;Initial Catalog=Test;UID=sa;Password=sa" />
</config> <config type="ConsoleApplication1.CastleActiveRecord.Test1Base , Learn.CUI">
<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=localhost;Initial Catalog=Test1;UID=sa;Password=sa" />
</config> <config type="ConsoleApplication1.CastleActiveRecord.Test2Base , Learn.CUI">
<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=localhost;Initial Catalog=Test2;UID=sa;Password=sa" />
</config>
</activerecord>

我们会发现,ActiveRecord 通过使用公用基类的方式来实现多个数据库连接配置的。只要继承自指定的基类,我们就可以使用不同的目标数据库。在配置文件中我们通过增加多个 Config Section,同时指定 Config Type 属性,就可以让 ActiveRecord 使用多数据库配置。Config Type 就是我们编写的基类,所有继承自该基类的类型都会使用该连接配置,而那些直接继承自 ActiveRecordBase 的类型还是使用缺省的连接配置。
上面的例子使用了 SQL Server 2000 的不同数据库,同样我们也可以连接到不同的数据库系统,如 A、B 连接到 SQL Server,C、D 连接到 DB2 等等。
2. 基类需要遵循一定的规则。
(1) 必须继承自 ActiveRecordBase。
(2) 必须是抽象类。
(3) 可以不添加 [ActiveRecord()] 特性。
(4) 必须初始化抽象基类。如 "ActiveRecordStarter.Initialize(source, typeof(Test1Base ));" ,如果使用 "ActiveRecordStarter.Initialize(Assembly.GetExecutingAssembly(), source);" 那么就给抽象基类添加 "[ActiveRecord()]" 即可。
下面是一个相对完整的代码演示。

namespace ConsoleApplication1.CastleActiveRecord
{
[ActiveRecord()]
public abstract class Base : ActiveRecordBase
{
} [ActiveRecord("Users")]
public class User : Base
{
private int id; [PrimaryKey(PrimaryKeyType.Identity)]
public int Id
{
get { Console.WriteLine("Id..."); return id; }
set { id = value; }
} private string name; [Property(Unique=true)]
public string Name
{
get { return name; }
set { name = value; }
}
} public class ActiveRecordTest
{
static ActiveRecordTest()
{
// 获取数据库连接配置
XmlConfigurationSource source = new XmlConfigurationSource(@"Config/ActiveRecord.xml"); // 载入程序集中所有 ActiveRecord 类。
ActiveRecordStarter.Initialize(Assembly.GetExecutingAssembly(), source); // 自主载入指定类型
//ActiveRecordStarter.Initialize(source, typeof(ActiveRecordBase), typeof(User), typeof(Base)); // 删除数据库架构
//ActiveRecordStarter.DropSchema(); // 创建数据库架构(该方法会删除同名表后再创建)
ActiveRecordStarter.CreateSchema();
} public static void Test()
{
User user = new User();
user.Name = "tom" + new Random(DateTime.Now.Millisecond).Next(); ActiveRecordMediator.Create(user);
}
}
}

ActiveRecord.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=localhost;Initial Catalog=Test2;UID=sa;Password=sa" />
</config> <config type="ConsoleApplication1.CastleActiveRecord.Base, Learn.CUI">
<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=localhost;Initial Catalog=Test;UID=sa;Password=sa" />
</config>
</activerecord>

-----------------
附:本文所有演示代码使用 2006-01-01 发布的 Castle ActiveRecord Beta3 版本。
Castle ActiveRecord 在发布 1.0 版本前可能有很多较大的变化,如演示代码无法编译,建议您参考最新版本的相关文档

最新文章

  1. 第四课 开发uehtml官网响应式静态页面
  2. 禁止root用户远程登录
  3. JS中的get &amp; set
  4. fir.im Weekly - 一切从知识重构开始
  5. winform时钟c#代码
  6. css 图片的无缝滚动
  7. cocos2d项目 打包apk 项目名称相关设置
  8. CART
  9. HDU 1532 Drainage Ditches EK算法 flod算法
  10. java中的substring用法
  11. 函数flst_add_last
  12. [Tommas] 测试场景 VS 测试用例 哪个更好?(转)
  13. Wooden Sticks(杭州电1051)
  14. ListView分页显示
  15. Keychain 浅析
  16. Xamarin.Forms(二) 返回页面的数据刷新
  17. JVM的内存分区
  18. Python自学编程开发路线图(文中有免费资源)
  19. MyBatis(九) 使用association定义单个对象的封装规则
  20. C#网络请求与JSON解析

热门文章

  1. 【BZOJ】1615: [Usaco2008 Mar]The Loathesome Hay Baler麻烦的干草打包机(模拟+bfs)
  2. VC++中CEdit控件实现回车换行
  3. MySQL Error: PROCEDURE xmdk.query_all_plan can&#39;t return a result set in the given context
  4. python入门(十):XML和JSON解析
  5. 剑指 offer set 20 打印出和为 s 的连续正序序列
  6. IOS 开发之 -- 获取本机通讯录里面所有的联系人,并传到后台
  7. JSON-Server 安装
  8. 输入一个long类型的整数,输出一个以金融格式表示的字符串
  9. 【BZOJ3681】Arietta 树链剖分+可持久化线段树优化建图+网络流
  10. MySql指令大全(转载)