数据访问模式之Repository模式

 

数据访问层无非就是对数据进行增删改查,其中增、删、改等我们可以抽象出来写一个公共的接口或抽象类来定义这些方法,并采用一个基类实现这些方法,这样该基类派生的子类都会继承增、删、改这些方法,这样我们就避免了每个实体都要重复实现这些方法。一句话概括就是:通过接口 泛型 与ORM结合 实现了数据访问层更好的复用。

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

下面我们就用EF来实现一个简单的Repository模式 

1、我们对实体的公共操作部分,提取为IRepository接口,比如常见的增加,删除、修改等方法。如下代码

我们发现接口的泛型TEntity有一个约束需要继承BaseEntity,BaseEntity就是把实体中公共的属性抽取出来,比如:Id(主键),CreateDate(创建时间)等。

  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using Repository.Model;
  6. using System.Data.Entity;
  7.  
  8. namespace Repository.Data
  9. {
  10. public interface IRepository<TEntity> where TEntity:BaseEntity
  11. {
  12. DbSet<TEntity> Entities { get; }
  13. //增加单个实体
  14. int Insert(TEntity entity);
  15. //增加多个实体
  16. int Insert(IEnumerable<TEntity> entities);
  17. //更新实体
  18. int Update(TEntity entity);
  19. //删除
  20. int Delete(object id);
  21. //根据逐渐获取实体
  22. TEntity GetByKey(object key);
  23.  
  24. }
  25. }

2、BaseEntity类

BaseEntity类中定义了所有参加数据操作实体的公共属性,因此我们把该类定义为抽象类,作为派生类的的基类。代码如下:

  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using System.ComponentModel.DataAnnotations;
  6.  
  7. namespace Repository.Model
  8. {
  9. public abstract class BaseEntity
  10. {
  11. public BaseEntity()
  12. {
  13. Id = Guid.NewGuid();
  14. CreateDate = DateTime.Now;
  15. }
  16. [Key]
  17. public Guid Id { get; set; }
  18. public DateTime CreateDate { get; set; }
  19. }
  20. }

3、IRepository接口定义完毕,肯定需要一个雷来实现接口中的方法,下面我们定义一个抽象类EFRepositoryBase来实现该接口方法

我们用一个抽象类EFRepositoryBase来实现接口中的方法,这样派生的类都具有接口中定义的方法,也防止EFRepositoryBase直接被实例化,下面我们直接看代码:

  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using Repository.Model;
  6. using System.Data.Entity;
  7.  
  8. namespace Repository.Data
  9. {
  10. public abstract class EFRepositoryBase<TEntity> : IRepository<TEntity> where TEntity:BaseEntity
  11. {
  12. DemoDbContext Db = new DemoDbContext();
  13.  
  14. #region IRepository<TEntity> 成员
  15.  
  16. public DbSet<TEntity> Entities
  17. {
  18. get { return Db.Set<TEntity>(); }
  19. }
  20.  
  21. public int Insert(TEntity entity)
  22. {
  23. Db.Set<TEntity>().Add(entity);
  24. return Db.SaveChanges();
  25. }
  26.  
  27. public int Insert(IEnumerable<TEntity> entities)
  28. {
  29. throw new NotImplementedException();
  30. }
  31. public int Update(TEntity entity)
  32. {
  33. return 0;
  34. }
  35. public int Delete(object id)
  36. {
  37. throw new NotImplementedException();
  38. }
  39.  
  40. public TEntity GetByKey(object key)
  41. {
  42. return Db.Set<TEntity>().Find(key);
  43.  
  44. }
  45.  
  46. #endregion
  47. }
  48. }

因为我们用的EF作为数据访问,因此我们需要定义一个数据上下文,代码如下

DemoDbContext()

数据库连接字符串

我们一共定义两个实体,一个是Members(学生)类和Scores(成绩)类,Members与Scores为一对多的关系。

4、Members类和Scores类,都要继承BaseEntity基类

Member

Score

基础工作都已经完成了,下面我们来看 MemberRepository.cs类和ScoreRespository.cs类。

所有的数据操作都在EFRepositoryBase.cs中实现了,因此MemberRepository.cs和ScoreRespository.cs只需要继承EFRepositoryBase,即可实现增删改查。

1、MemberRepository.cs

MemberRepository为实体Member的操作类,因此EFRepositoryBase基类中的泛型被替换成实体Member,这样该类中就已经有了对Member的增删改查操作,我们也可以在MemberRepository中定义其他方法。

  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using Repository.Model;
  6.  
  7. namespace Repository.Data
  8. {
  9. public class MemberRepository : EFRepositoryBase<Member>, IRepository<Member>
  10. {
  11. }
  12.  
  13. }

2、ScoreRespository.cs

ScoreRespository与MemberRepository一样,只不过是对实体Score的操作。

3、简单测试

  1. public void test()
  2. {
  3. MemberRepository mr = new MemberRepository();
  4. var entity = new Member()
  5. {
  6. UserName = "eric",
  7. Age = 25,
  8. Sex = "男"
  9. };
  10. mr.Insert(entity);
  11.  
  12. var score = new Score()
  13. {
  14. MemberId = entity.Id,
  15. Scores = 80,
  16. courseId = Guid.NewGuid()
  17. };
  18. ScoreRespository sr = new ScoreRespository();
  19. sr.Insert(score);
  20. }

我们发现数据操作成功。

一般Repository都会跟Unit of Work模式联合使用,如果你有好的学习资料欢迎分享,Unit of Work模式曾看了一天也没有理解其精髓。

每天学习一点点,每天进步一点点。

 
 

数据访问模式之Repository模式的更多相关文章

  1. 项目架构开发:数据访问层之Repository

    接上文 项目架构开发:数据访问层之Logger 本章我们继续IRepository开发,这个仓储与领域模式里边的仓储有区别,更像一个工具类,也就是有些园友说的“伪仓储”, 这个仓储只实现单表的CURD ...

  2. 数据访问层之Repository

    数据访问层之Repository   接上文 项目架构开发:数据访问层之Logger 本章我们继续IRepository开发,这个仓储与领域模式里边的仓储有区别,更像一个工具类,也就是有些园友说的“伪 ...

  3. Hibernate(1)——数据访问层的架构模式

    俗话说,自己写的代码,6个月后也是别人的代码……复习!复习!复习!涉及到的知识点总结如下: 数据库的概念.逻辑.数据模型概念 应用程序的分层体系结构发展 MVC设计模式与四层结构的对应关系 持久层的设 ...

  4. Hibernate(1)——数据访问层的架构模式<转>

    数据库的概念.逻辑.数据模型概念 应用程序的分层体系结构发展 MVC设计模式与四层结构的对应关系 持久层的设计目标 数据映射器架构模式 JDBC的缺点 Hibernate简介 迅速使用Hibernat ...

  5. 使用ASP.NET Web Api构建基于REST风格的服务实战系列教程【二】——使用Repository模式构建数据库访问层

    系列导航地址http://www.cnblogs.com/fzrain/p/3490137.html 前言 在数据访问层应用Repository模式来隔离对领域对象的细节操作是很有意义的.它位于映射层 ...

  6. 使用Repository模式构建数据库访问层

    使用Repository模式构建数据库访问层 使用ASP.NET Web Api构建基于REST风格的服务实战系列教程[二]——使用Repository模式构建数据库访问层 系列导航地址http:// ...

  7. 项目架构开发:数据访问层之Cache

    数据访问层简单介绍 数据访问层,提供整个项目的数据访问与持久化功能.在分层系统中所有有关数据访问.检索.持久化的任务,最终都将在这一层完成. 来看一个比较经典的数据访问层结构图 大概可以看出如下信息 ...

  8. 项目架构开发:数据访问层之Logger

    接上文 项目架构开发:数据访问层之Cache 本章我们继续ILogger的开发 ILogger.cs public interface ILogger { void Info(object messa ...

  9. 项目架构开发:数据访问层之UnitOfWork

    接上文 项目架构开发:数据访问层之IQuery 本章我们继续IUnitOfWork的开发,从之前的IRepository接口中就可以看出,我们并没有处理单元事务, 数据CUD每次都是立即执行的,这样有 ...

随机推荐

  1. hdu 1002 Java 大数 加法

    http://acm.hdu.edu.cn/showproblem.php?pid=1002 PE   由于最后一个CASE不须要输出空行 import java.math.BigInteger; i ...

  2. MVC Bootstrap Helpers

    ASP.NET MVC Bootstrap Helpers   阅读目录 序言 内置的HTML Helpers 创建自定义的Helpers 使用静态方法创建Helpers 使用扩展方法创建Helper ...

  3. Hibernate制图(两)——许多-于─关系映射

    上篇学习了Hibernate的基本映射,也就是单表映射,非常easy就能理解,可是对于关系数据库来说,表之间存在关系是比不可少的.关系数据库中存在的关系是通过主外键建立起来的.反应到Hibernate ...

  4. Set Matrix Zeroes -- LeetCode

    原题链接: http://oj.leetcode.com/problems/set-matrix-zeroes/ 这是一个矩阵操作的题目,目标非常明白,就是假设矩阵假设有元素为0,就把相应的行和列上面 ...

  5. qml能够这么玩

    Qt 5以后qmlscene被qml所替代,/usr/bin/qml能够用来执行.qml文件.所以,我们就能够和sh一样的来写界面了. #!/usr/bin/env qml import QtQuic ...

  6. 使用.NET REACTOR制作软件许可证

    原文:使用.NET REACTOR制作软件许可证 软件下载地址:http://www.eziriz.com/downloads.htm 做一个简单的许可证系统,下面是具体步骤: 1,  OPEN AS ...

  7. Markdown的使用

    原文:http://wowubuntu.com/markdown/ git:https://gitcafe.com/riku/Markdown-Syntax-CN/ 记录一下Markdown的使用,I ...

  8. .NET代码自动编译发布

    .NET代码自动编译发布   因本人一直使用.NET开发,在做项目的时候,每次都要涉及到各个环境的部署问题,手工操作容易出错,并且重复劳动多,所以一直在寻找一个能实现自动化部署的方案. 废话不多讲,先 ...

  9. Asp.Net MVC 上传图片到数据库

    [读书笔记]Asp.Net MVC 上传图片到数据库(会的绕行)   之前上传图片的做法都是上传到服务器上的文件夹中,再将url保存到数据库.其实在MVC中将图片上传到数据库很便捷的事情,而且不用去存 ...

  10. SQL练习1关于插入删除,修改,单表查询

    --创建数据库create database studentsDB --创建表create table student( id int primary key, stuid char(10), stu ...