使用DapperSimpleCRUD对Repository层进行封装
通过前面的两篇文章使用Dapper操作Mysql数据库与使用Dapper进行参数化查询,大致介绍了Dapper的一些基本操作和简单使用,在实际的使用当中,我们可以把项目简单的分为MVC+Service层+Repository层,Repository 是一个独立的层,在这里我们简单的把它当作 DAO 来看待,结合 DapperSimpleCRUD 提供数据的CRUD操作;但在领域驱动设计中,我们应该采用面向集合的方式,而不是面向数据访问的方式设计仓储。这有助于你将自己的领域当作模型来看待,而不是 CRUD 操作。
DapperSimpleCRUD 是针对Dapper进行的扩展,通过简单的配置把数据表与实体模型进行匹配,达到对象和数据库之间映射;你可以通过gtihub下载引用,也可以直接在nuget上直接引用。
我们实际操作一下
1、创建Car表,包含Id,Car_Id,Create_Time三列,创建对应的实体模型;务必添加[Table]和[Key]标签,DapperSimpleCRUD 才能获取到实体对象对应的数据库表和主键
/// <summary> /// UserInfo表实体对象映射 /// </summary> [Table("UserInfo")] public class UserInfo { [Key] public string Id { get; set; } public string User_Name { get; set; } public int Enable { get; set; } }
2、创建泛型接口 IBaseRepository,定义你需要的基本数据操作
/// <summary> /// 接口层Device /// </summary> public interface IBaseRepository<T> { #region 成员方法 /// <summary> /// 增加一条数据 /// </summary> bool Add(T model); /// <summary> /// 根据ID删除一条数据 /// </summary> bool Delete(int Id); /// <summary> /// 根据条件删除数据 /// </summary> /// <param name="strWhere"></param> /// <param name="parameters"></param> /// <returns></returns> bool DeleteList(string strWhere, object parameters); /// <summary> /// 更新一条数据 /// </summary> bool Update(T model); /// <summary> /// 根据ID获取实体对象 /// </summary> T GetModel(int Id); ///// <summary> ///// 根据条件获取实体对象 ///// </summary> //T GetModel(string strWhere, object parameters); /// <summary> /// 根据条件获取实体对象集合 /// </summary> /// <param name="strWhere"></param> /// <param name="parameters"></param> /// <returns></returns> IEnumerable<T> GetModelList(string strWhere, object parameters); /// <summary> /// 分页查询 /// </summary> /// <param name="pageNum">页码</param> /// <param name="rowsNum">每页行数</param> /// <param name="strWhere">where条件</param> /// <param name="orderBy">Orde by排序</param> /// <param name="parameters">parameters参数</param> /// <returns></returns> IEnumerable<T> GetListPage(int pageNum, int rowsNum, string strWhere, string orderBy, object parameters); #endregion }
3、BaseRepository 实现接口定义
/// <summary> /// 仓储层基类,通过泛型实现通用的CRUD操作 /// </summary> /// <typeparam name="T"></typeparam> public class BaseRepository<T> : IBaseRepository<T> { private IDbConnection _connection; #region 成员方法 /// <summary> /// 增加一条数据 /// </summary> public bool Add(T model) { int? result; using (_connection = Utilities.GetOpenConnection()) { result = _connection.Insert<T>(model); } ) { return true; } else { return false; } } /// <summary> /// 根据ID删除一条数据 /// </summary> public bool Delete(int id) { int? result; using (_connection = Utilities.GetOpenConnection()) { result = _connection.Delete<T>(id); } ) { return true; } else { return false; } } /// <summary> /// 按条件删除数据 /// </summary> /// <param name="strWhere"></param> /// <param name="parameters"></param> /// <returns></returns> public bool DeleteList(string strWhere, object parameters) { int? result; using (_connection = Utilities.GetOpenConnection()) { result = _connection.DeleteList<T>(strWhere,parameters); } ) { return true; } else { return false; } } /// <summary> /// 更新一条数据 /// </summary> public bool Update(T model) { int? result; using (_connection = Utilities.GetOpenConnection()) { result = _connection.Update<T>(model); } ) { return true; } else { return false; } } /// <summary> /// 根据ID获取实体对象 /// </summary> public T GetModel(int id) { using (_connection = Utilities.GetOpenConnection()) { return _connection.Get<T>(id); } } /// <summary> /// 根据条件获取实体对象集合 /// </summary> public IEnumerable<T> GetModelList(string strWhere, object parameters) { using (_connection = Utilities.GetOpenConnection()) { return _connection.GetList<T>(strWhere, parameters); } } /// <summary> /// 根据条件分页获取实体对象集合 /// </summary> /// <param name="pageNum"></param> /// <param name="rowsNum"></param> /// <param name="strWhere"></param> /// <param name="orderBy"></param> /// <param name="parameters"></param> /// <returns></returns> public IEnumerable<T> GetListPage(int pageNum,int rowsNum, string strWhere, string orderBy,object parameters) { using (_connection = Utilities.GetOpenConnection()) { return _connection.GetListPaged<T>(pageNum, rowsNum, strWhere, orderBy, parameters); ; } } #endregion }
4、下面User实体对应的Repository类实现如下,DapperSimpleCRUD 通过传入的泛型类型自动完成对象与数据库的关系映射
public class UserInfoRepository : BaseRepository<UserInfo>,IUserInfoRepository { public UserInfo ValidateUser(string strUser) { UserInfo user = new UserInfo(); try { DynamicParameters Parameters = new DynamicParameters(); string strQuery = "WHERE User_Name=@Name"; Parameters.Add("Name", strUser); return this.GetModelList(strQuery, Parameters).First(); } catch { return user; } } }
上面是对Repository层的一个简单封装,通过DapperSimpleCRUD对Dapper的扩展,实现对象与数据库的自动映射,可以完成通用的CRUD操作,简化了一些重复性的代码。
使用DapperSimpleCRUD对Repository层进行封装的更多相关文章
- 【redis】5.spring boot项目中,直接在spring data jpa的Repository层使用redis +redis注解@Cacheable直接在Repository层使用,报错问题处理Null key returned for cache operation
spring boot整合redis:http://www.cnblogs.com/sxdcgaq8080/p/8028970.html 首先,明确一下问题的场景 之前在spring boot整合re ...
- ASP.NET MVC+EF框架+EasyUI实现权限管理系列(4)-业务逻辑层的封装
原文:ASP.NET MVC+EF框架+EasyUI实现权限管理系列(4)-业务逻辑层的封装 ASP.NET MVC+EF框架+EasyUI实现权限管系列 (开篇) (1):框架搭建 (2) ...
- ASP.NET 一个数据访问层的封装
刚通过开通写博客的申请,向博客园的大佬致敬,由于一直以来都在网上搜索大家的思想,也有翻遍整个百度都有的找不到的时候,作为一个网民理应为互联网贡献一点东西. 下面是我工作后受一个师傅的影响对数据库访问层 ...
- 关于dao层的封装和前端分页的结合(文章有点长,耐心点哦)
任何一个封装讲究的是,实用,多状态.Action: 任何一个Action继承分页有关参数类PageManage,自然考虑的到分页效果,我们必须定义下几个分页的参数.并根据这个参数进行查值. 然 ...
- 带分页功能的SSH整合,DAO层经典封装
任何一个封装讲究的是,使用,多状态.Action: 任何一个Action继承分页有关参数类PageManage,自然考虑的到分页效果,我们必须定义下几个分页的参数.并根据这个参数进行查值. 然 ...
- angular开发中对请求数据层的封装
代码地址如下:http://www.demodashi.com/demo/11481.html 一.本章节仅仅是对angular4项目开发中数据请求封装到model中 仅仅是在项目angular4项目 ...
- DB First 中对Repository 层封装的几点小记
在数据库表创建完成的情况下,使用DB First 进行开发,封装底层会遇到一些小问题,在此记录一下,供以后参考. 主要解决的问题有: 1.EF上下文管理 2.BaseRepository的封装 3.E ...
- 通过对DAO层的封装减少数据库操作的代码量
在学框架之前,写项目时总是要花大量的时间去写数据库操作层代码,这样会大大降低我们的效率,为了解决这个问题,我花了两天时间利用反射机制和泛型将DAO层进行了封装,这样我们只需要写sql语句,不需要再写 ...
- JavaEE中的MVC(一)Dao层彻底封装
最近Android工作实在难找,考虑是不是该转行做Java了,今天开始,花几天的事件,研究一下JavaEE各层优化. 首先是Dao层 增删改方法封装 使用PreparedStatement执行一条Sq ...
随机推荐
- CGI + FastCGI(PHP-FPM)联系和区别的图解 + 注释
一.背景 参考了几篇文章,总结成图解 + 注释方便以后查阅. 参考资料: 1.https://www.zhihu.com/question/19582041 2.https://segmentfaul ...
- Membership ——入门基础
Membership是ASP.NET为我们提供的一套验证和存储用户凭证的框架.它可以帮助我们快速的开发用户登录.管理以及权限验证相关的模块,很多人可能会说Membership开发起来确实很快,但是总是 ...
- 2nd_SE-结对编程1-基于flask框架的四则运算生成器
0x00 Coding https://coding.net/u/nikochan/p/2nd_SE/git 0x01 写在前面 因为在上一个作业中,是基于python完成的Command程序.那么再 ...
- Windows环境下JDK的下载与安装
根据极客学院上的网课做的学习笔记,网课地址:http://www.jikexueyuan.com/course/205.html 1.首先检查一下本机是否有安装java.按win+R,在弹出窗口中输入 ...
- 展示博客(Beta阶段)
展示博客 0x00 团队成员 成员 博客地址 简介 黄建英 http://www.cnblogs.com/smilehjy/ beta阶段的新成员,负责前端界面调整 谢晓萍 http://www.cn ...
- 201521123085 《JAVA程序设计》第6周学习总结
1. 本周学习总结 1.1 面向对象学习暂告一段落,请使用思维导图,以封装.继承.多态为核心概念画一张思维导图,对面向对象思想进行一个总结. 2. 书面作业 1.clone方法 1.1 Object对 ...
- 201521123012 《Java程序设计》第二周学习总结
1. 本章学习总结 1.Java中String和StringBuilder的区别. 2.Arrays()的用法. 2.课后作业 1.使用Eclipse关联jdk源代码(截图),并查看String对象的 ...
- html css 前端基础 学习方法及经验分享
前言: 入园第一天,想分享一点儿前端基础html css 的学习方法和一些经验给热爱前端,但是不知道从哪儿开始,依旧有些迷茫的新手朋友们.当然,适合每个人的学习方式不同,以下所讲的仅供参考. 一.关于 ...
- 在腾讯云上搭建WordPress博客
笔者一直很羡慕那些搭建了个人博客的大牛,在最近工作之余也尝试着搭建了自己的博客,历时1周,这篇文章就将踩过的坑记录下来,先看下成果,链接在此 1- 购买腾讯云主机 腾讯云官网,我选了79元/月的最便宜 ...
- Windbg调试(关于句柄表的获取,32位)
今天利用Windbg(x86)进行了获得句柄表的调试,从中获益良多,对调试步骤和按键又一次进行了熟悉,对于句柄表页的概念更是得到了进一步的清晰认识.windbg调试和句柄表不熟悉的朋友可以借鉴我的调试 ...