[Reference][Castle AR] 1. Starter

http://www.rainsts.net/article.asp?id=483
以前研究过一阵 ORM,基于某些理由,比较喜欢 XPO 和 Castle ActiveRecord。原因不外乎以下几点:
  • "Class to DB",我觉得 ORM 最重要的目的是用一种简便的方式来存储对象。我们对业务分析的重点是对象,而不会优先考虑数据库设计。XPO 和 Castle AR 在这方面做得都很好。
  • 一个是著名厂商 DevExpress 的产品,另一个是被广泛使用的 NHibernate 的封装,较好的升级保障对于项目开发是很重要的。网上一些个人的 ORM 作品虽然很有特色,但毕竟没人能保证 "未来三天" 它是否依然存在,也没有人能保证 Bug 会得到修复。
  • 这两个组件都能得到较好的技术支持,XPO 是商业软件自不必说,NHibernate 的用户群组和开发资料网上也很多。
  • 基于开发成本考虑,这两套组件无论是代码维护还是人力资源上都有较好的性价比。
  • 最后就是我个人对用于映射的配置文件有那么点 "偏见"。除非是改造现有系统,否则这些配置文件几乎不会发生改变。基于特性的映射将数据库、配置文件、实体类三个变化源归纳到一起,更好维护一些。
最近打算用 ORM 做点东西,细细衡量之下,还是选择 Castle AR,毕竟 "OpenSource" 的授权方式还是比较吸引人的。看了看以前写的 AR 文章,有点简单,有点落后,所以再写一点,应该没有炒剩饭的嫌疑。

------------ 以上都是题外话,就此打住!----------------------

AR 中有个类叫 ActiveRecordStarter,它是 AR 运行的起始点。我们就用它拉开序幕,重新研究 Castle AR RC2 的功能和特点。特别申明,我使用的 Castle 版本是从 Build Server 获取的最新编译版本 (castleproject-1.1-build_382-net-2.0-debug.zip)。

ActiveRecordStarter 的核心任务是获取所有 ActiveRecord 实体类型的信息,并创建 ActiveRecordModel。当然,ActiveRecordStarter 作用远不止如此。

1. 创建数据库连接

AR 沿用了 NHibernate 的配置习惯,我们可以使用配置文件,也可以使用代码。虽然我们可以使用默认方式,将配置信息写入 App.config / web.config,但我建议你使用单独的配置文件更好维护一些。

ar.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="server=(local);uid=sa;pwd=123456;database=test" />
  </config>
</activerecord>

XmlConfigurationSource
XmlConfigurationSource config = new XmlConfigurationSource("ar.xml");
ActiveRecordStarter.Initialize(Assembly.GetCallingAssembly(), config);


当然,我们还可以使用代码来代替配置文件。(注意添加 Castle.Core.dll 的引用。)
InPlaceConfigurationSource config = 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", "server=(local);uid=sa;pwd=123456;database=test");

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

ActiveRecordStarter.Initialize(Assembly.GetCallingAssembly(), config);

uploads/200705/08_103129_ar1.gif


2. 初始化实体类

方式1:指定具体实体类型。
ActiveRecordStarter.Initialize(config, typeof(User), typeof(Order));

方法2:指定程序集,初始化程序集中所有实体类型。 (使用重载方法,我们可以指定多个程序集。)
ActiveRecordStarter.Initialize(Assembly.GetExecutingAssembly(), config);

方法3:后续注册。
ActiveRecordStarter.Initialize(Assembly.GetExecutingAssembly(), config);
ActiveRecordStarter.RegisterTypes(typeof(User));

由于 Initialize 只能执行一次,所以 "后续注册" 就非常有用了,如果你看过我写的有关 CodeDom / Emit 方面的文章,就会明白动态构造类型对于 ORM 有些什么好处。
public static void Initialize(IConfigurationSource source, params Type[] types)
{
  lock (lockConfig)
  {
    if (isInitialized)
    {
      throw new ActiveRecordInitializationException("You can't invoke ActiveRecordStarter.Initialize more than once");
    }
    ...
  }
}

3. 创建数据库架构

初始化类型之后,我们可以用 ActiveRecordStarter 提供的方法创建所需的实体数据表了。
// 删除架构
ActiveRecordStarter.DropSchema();

// 创建架构
ActiveRecordStarter.CreateSchema();

// 创建相关 SQL 脚本。
ActiveRecordStarter.GenerateCreationScripts("create.sql");
ActiveRecordStarter.GenerateDropScripts("drop.sql");

最后,我们写一个完整一些的例子。
[ActiveRecord("Users")]
public class User
{
  private int id;

  [PrimaryKey(Generator=PrimaryKeyType.Identity)]
  public int Id
  {
    get { return id; }
    set { id = value; }
  }

  private string name;

  [Property(Unique=true, NotNull=true)]
  public string Name
  {
    get { return name; }
    set { name = value; }
  }

}

public class ARTester
{
  public static void Test()
  {
    InPlaceConfigurationSource config = 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", "server=(local);uid=sa;pwd=123456;database=test");
    config.Add(typeof(ActiveRecordBase), properties);

    ActiveRecordStarter.Initialize(Assembly.GetExecutingAssembly(), config);

    ActiveRecordStarter.DropSchema();
    ActiveRecordStarter.CreateSchema();

    //ActiveRecordStarter.GenerateCreationScripts("create.sql");
    //ActiveRecordStarter.GenerateDropScripts("drop.sql");
  }
}

转载于:https://www.cnblogs.com/jerryzhao/archive/2008/01/23/1049417.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值