在LinqToSql中如何应用Repository模式

来源:互联网 发布:流放之路装备数据 编辑:程序博客网 时间:2024/05/21 08:03

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();    }} 

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

原创粉丝点击