zoukankan      html  css  js  c++  java
  • [转载]ASP.NET MVC的例子中都使用了Repository模式

    在Asp.net MVC controller的底层,常常有提到repository和service layer, 好像都是逻辑相关的层,那么它们到底是什么区别呢?

    简单的说:

    repository就是一个管理数据持久层的,它负责数据的CRUD(Create, Read, Update, Delete)

    service layer是业务逻辑层,它常常需要访问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();
        }
    } 

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

    作者:生鱼片
             
    本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
  • 相关阅读:
    Mysql:为什么用limit时,offset很大会影响性能
    [解决方案]未能找到路径“~in oslyncsc.exe”的一部分
    [经验分享]NuGet发布自己的Dll(类库包)
    [解决方案]使用百度富文本编辑器,编辑显示不了内容
    [解决方案]未能加载文件或程序集
    [经验分享]WebApi+SwaggerUI 完美展示接口
    [经验分享]Linux网络连接-VMware+CentOS 7
    [经验分享]WebAPI中返回类型JsonMessage的应用
    [解决方案]WebAPI+SwaggerUI部署服务器后,访问一直报错的问题
    [解决方案] 当 IDENTITY_INSERT 设置为 OFF 时
  • 原文地址:https://www.cnblogs.com/fx2008/p/2832856.html
Copyright © 2011-2022 走看看