一、ActiveRecord与Castle ActiveRecord

    ActiveRecord是《Patterns of Enterprise Application Architecture》中描述的著名模式。基本上,当实例每一行的时候,所有的静态方法会作用于全部纪录。
    Castle ActiveRecord 是ActiveRecord 模式的一个实现,Castle ActiveRecord依赖Nhibernate来完成实际的映像。与单纯的ActiveRecord 相比,Castle ActiveRecord具有以下特点:

  •  敏捷开发(它尽可能多地处理了映射和推断,因此,对你的方案而言,当一些东西发生变化的时候,你不必去钻研文档或者处理大量的xml文档)

  • 预定了像Create, Update, Save, Delete这样的公共方法。

  • 容易实现像Find, FindAll, FindByName等此类的方法。

  • 绘画和事务范围(Session and transaction scopes that abstracts the ISession and translates them to a more natural idiom )

使用Nhibernate,你繁琐的配置工作多于复杂的映射,而使用ActiveRecord却是推进你的生产力的一个保证,你不必再为编写繁冗复杂的映射文件而头疼,ActiveRecord封装了NHibernate的操作,使用特性来代替映射文件,无论何时你需要,ActiveRecord都能给你一个Isession实例,它提供的简洁的O/R映射会让你为实现持久化数据层是那么简单而惊叹!

Castle的官网是http://www.castleproject.org/,这里的文章都参考于此。
二、开始

1、准备工作:

(1)需要引用的程序集:

  • Castle.ActiveRecord.dll

  • Castle.Model.dll

  • Nullables.dll

  • NHibernate.dll

  • Castle.DynamicProxy.dll (Curious? Check DynamicProxy)

  • Nullables.NHibernate.dll

  • log4net.dll

  • Iesi.Collections.dll

(2)一个简单的控制台工程
(3)数据库

Castle ActiveRecord(一)概述CREATE TABLE Blogs (
Castle ActiveRecord(一)概述    blog_id     
int IDENTITY(11PRIMARY KEY,
Castle ActiveRecord(一)概述    blog_name   
varchar(50),
Castle ActiveRecord(一)概述    blog_author 
varchar(50))
Castle ActiveRecord(一)概述
Castle ActiveRecord(一)概述
CREATE TABLE Posts (
Castle ActiveRecord(一)概述    post_id        
int IDENTITY(11PRIMARY KEY,
Castle ActiveRecord(一)概述    post_title     
varchar(50),
Castle ActiveRecord(一)概述    post_contents  
text,
Castle ActiveRecord(一)概述    post_category  
varchar(50),
Castle ActiveRecord(一)概述    post_blogid    
int FOREIGN KEY REFERENCES Blogs (blog_id),
Castle ActiveRecord(一)概述    post_created   
datetime,
Castle ActiveRecord(一)概述    post_published 
bit
Castle ActiveRecord(一)概述)
Castle ActiveRecord(一)概述
Castle ActiveRecord(一)概述


2、编写Blog 类

首先让我们编写一个继承于ActiveRecordBase的类Blog 。

Castle ActiveRecord(一)概述public class Blog : ActiveRecordBase

接下来你必须使用ActiveRecordAttribute来让Blog 类知道对应数据库的哪个表。注意这件事情,类的名称是Blog ,而数据表的名称是Blogs,如果这两者相同,这个地方可以不特别指定类对应的数据表。

Castle ActiveRecord(一)概述[ActiveRecord("Blogs")]
Castle ActiveRecord(一)概述
public class Blog : ActiveRecordBase

接下来让我们为类添加属性并指定主键吧:

Castle ActiveRecord(一)概述[ActiveRecord("Blogs")]
Castle ActiveRecord(一)概述
public class Blog : ActiveRecordBase


在这个例子中,主键需要对应到数据表中的blog_id字段。与上面相同,如果数据表中主键名称和属性名称相同的话,这个地方也不需要特别指定对应关系,这会使事情更加简单,例如,如果主键的字段名称也是Id,下面这样就可以了:

Castle ActiveRecord(一)概述[PrimaryKey]
Castle ActiveRecord(一)概述
public int Id


最后让我们来看完成映射关系的类:

Castle ActiveRecord(一)概述using System;
Castle ActiveRecord(一)概述
using System.Collections.Generic;
Castle ActiveRecord(一)概述
using System.Text;
Castle ActiveRecord(一)概述
using Castle.ActiveRecord;
Castle ActiveRecord(一)概述
Castle ActiveRecord(一)概述
namespace ActiveRecord
}

我们把类映射到了数据表、字段和主键,代码非常直白。在开始测试之前,我们还必须提供一些配置信息,这些信息包含了数据库联接的一些设置,我们可以使用AppDomain Config文件来保存这些信息,也可以使用硬编码的方式:

Castle ActiveRecord(一)概述<code>
Castle ActiveRecord(一)概述
<?xml version="1.0" encoding="utf-8" ?> 
Castle ActiveRecord(一)概述
<configuration>
Castle ActiveRecord(一)概述    
<configSections>
Castle ActiveRecord(一)概述        
<section name="activerecord"
Castle ActiveRecord(一)概述type
="Castle.ActiveRecord.Framework.Config.ActiveRecordSectionHandler, Castle.ActiveRecord"/>
Castle ActiveRecord(一)概述    
</configSections>
Castle ActiveRecord(一)概述    
<activerecord>
Castle ActiveRecord(一)概述      
<config>
Castle ActiveRecord(一)概述        
<add key="hibernate.connection.driver_class" value="NHibernate.Driver.SqlClientDriver" />
Castle ActiveRecord(一)概述        
<add key="hibernate.dialect" value="NHibernate.Dialect.MsSql2000Dialect" />
Castle ActiveRecord(一)概述        
<add key="hibernate.connection.provider" value="NHibernate.Connection.DriverConnectionProvider" />
Castle ActiveRecord(一)概述        
<add key="hibernate.connection.connection_string" value="UID=sa;Password=yourpass;Initial Catalog=test;Data Source=." />
Castle ActiveRecord(一)概述      
</config>
Castle ActiveRecord(一)概述    
</activerecord>
Castle ActiveRecord(一)概述
</configuration>
Castle ActiveRecord(一)概述
</code>
Castle ActiveRecord(一)概述
Castle ActiveRecord(一)概述

或者:

Castle ActiveRecord(一)概述 InPlaceConfigurationSource source = new InPlaceConfigurationSource();
Castle ActiveRecord(一)概述            Hashtable properties 
= new Hashtable();
Castle ActiveRecord(一)概述            properties.Add(
"hibernate.connection.driver_class""NHibernate.Driver.SqlClientDriver");
Castle ActiveRecord(一)概述            properties.Add(
"hibernate.dialect""NHibernate.Dialect.MsSql2000Dialect");
Castle ActiveRecord(一)概述            properties.Add(
"hibernate.connection.provider""NHibernate.Connection.DriverConnectionProvider");
Castle ActiveRecord(一)概述            properties.Add(
"hibernate.connection.connection_string""UID=sa;Password=;Initial Catalog=test;Data Source=.");
Castle ActiveRecord(一)概述            source.Add(
typeof(ActiveRecordBase), properties);
Castle ActiveRecord(一)概述            ActiveRecordStarter.Initialize(source, 
typeof(Blog));


在这个例子中,我们可以象下面这样初始化:

Castle ActiveRecord(一)概述IConfigurationSource source = System.Configuration.ConfigurationSettings.GetConfig("activerecord"as IConfigurationSource;
Castle ActiveRecord(一)概述            ActiveRecordStarter.Initialize(source, 
typeof(Blog));

现在你能够象下面这样运行程序了:

Castle ActiveRecord(一)概述//删除所有
Castle ActiveRecord(一)概述
Blog.DeleteAll();
Castle ActiveRecord(一)概述
//添加
Castle ActiveRecord(一)概述
Blog blog = new Blog();
Castle ActiveRecord(一)概述blog.Name 
= "ttinfo";
Castle ActiveRecord(一)概述blog.Author
="ttinfo2";
Castle ActiveRecord(一)概述blog.Save(); 
// or blog.Create();
Castle ActiveRecord(一)概述
//按照id查询
Castle ActiveRecord(一)概述
Int id=1;
Castle ActiveRecord(一)概述Blog blog
= Blog.Find(id);
Castle ActiveRecord(一)概述……
Castle ActiveRecord(一)概述
Castle ActiveRecord(一)概述

怎么样,Castle ActiveRecord够简单了吧,其实还能够更简单呢,Castle ActiveRecord里面有一个工具,可以自动生成映射类,下一节将介绍。

相关文章: