Repository 模式

近来发现很多ASP.NET MVC的例子中都使用了Repository模式,比如Oxite,ScottGu最近发布的免费的ASP.NET MVC教程都使用了该模式。就简单看了下。

在《企业架构模式》中,译者将Repository翻译为资源库。给出如下说明:
通 过用来访问领域对象的一个类似集合的接口,在领域与数据映射层之间进行协调。

在《领域驱动设计:软件核心复杂性应对之 道》中,译者将Repository翻译为仓储,给出如下说明:
一种用来封装存储,读取和查找行为的机制,它模拟了一个对象集 合。

使用该模式的最大好处就是将领域模型从客户代码和数据映射层之间解耦出来。

我们来看下在 LinqToSql中如何应用该模式。
1. 我们将对实体的公共操作部分,提取为IRepository接口,比如常见的增加,删除等方法。如下代码:

interface 
IRepository
<T> where 
T : class
{
IEnumerable <T> FindAll(Func <T, bool > exp);
void Add(T entity);
void Delete(T entity);
void Save();
}

2.下面我们实现一个泛型的类来具体实现上面的接口的方法。

public class 
Repository
<T> : IRepository<T> where 
T : class
{
public DataContext context;
public Repository(DataContext context)
{
this .context = context;
}
public IEnumerable <T> FindAll(Func <T, bool > exp)
{
return context.GetTable<T>().Where(exp);
}
public void Add(T entity)
{
context.GetTable<T>().InsertOnSubmit(entity);
}
public void Delete(T entity)
{
context.GetTable<T>().DeleteOnSubmit(entity);
}
public void Save()
{
context.SubmitChanges();
}
}

3.上面我们实现是每个实体公共的操作,但是实际中每个实体都有符合自己业务的逻辑。我们单独定义另外一个接口,例如:

interface 
IBookRepository 
: IRepository<Book>
{
IList <Book> GetAllByBookId(int id);
}

4.最后该实体的Repository类实现如下:

public class 
BookRepository 
: Repository<Book>, IBookRepository
{
public BookRepository(DataContext dc)
: base (dc)
{ }
public IList <Book> GetAllByBookId(int id)
{
var listbook = from c in context.GetTable<Book>()
where c.BookId == id
select c;
return listbook.ToList();
}
}

上面只是为大家提供了一个最基本使用框架。

作者: 生鱼片
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的 权利。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值