c# 封装Dapper操作类
using Dapper; using DapperExtensions; using System.Collections.Generic; using System.Configuration; using System.Data; using System.Data.SqlClient; using System.Linq; using System.Threading.Tasks; namespace DBLibrarys.DBHelper { /// <summary> /// 数据库操作类 /// </summary> public class SqlDapperHelper { static string connStrRead = ConfigurationManager.ConnectionStrings["Read"].ConnectionString; static string connStrWrite = ConfigurationManager.ConnectionStrings["Write"].ConnectionString; ; public static IDbConnection GetConnection(bool useWriteConn) { if (useWriteConn) return new SqlConnection(connStrWrite); return new SqlConnection(connStrRead); } public static SqlConnection GetOpenConnection() { var conn = new SqlConnection(connStrWrite); conn.Open(); return conn; } /// <summary> /// 执行sql返回一个对象 /// </summary> /// <typeparam name="T"></typeparam> /// <param name="sql"></param> /// <param name="param"></param> /// <param name="useWriteConn"></param> /// <returns></returns> public static T ExecuteReaderReturnT<T>(string sql, object param = null, bool useWriteConn = false, IDbTransaction transaction = null) { if (transaction == null) { using (IDbConnection conn = GetConnection(useWriteConn)) { conn.Open(); return conn.QueryFirstOrDefault<T>(sql, param, commandTimeout: commandTimeout); } } else { var conn = transaction.Connection; return conn.QueryFirstOrDefault<T>(sql, param, commandTimeout: commandTimeout, transaction: transaction); } } /// <summary> /// 执行sql返回多个对象 /// </summary> /// <typeparam name="T"></typeparam> /// <param name="sql"></param> /// <param name="param"></param> /// <param name="useWriteConn"></param> /// <returns></returns> public static List<T> ExecuteReaderReturnList<T>(string sql, object param = null, bool useWriteConn = false, IDbTransaction transaction = null) { using (IDbConnection conn = GetConnection(useWriteConn)) { conn.Open(); return conn.Query<T>(sql, param, commandTimeout: commandTimeout, transaction: transaction).ToList(); } } /// <summary> /// 执行sql返回一个对象--异步 /// </summary> /// <typeparam name="T"></typeparam> /// <param name="sql"></param> /// <param name="param"></param> /// <param name="useWriteConn"></param> /// <returns></returns> public static async Task<T> ExecuteReaderRetTAsync<T>(string sql, object param = null, bool useWriteConn = false) { using (IDbConnection conn = GetConnection(useWriteConn)) { conn.Open(); return await conn.QueryFirstOrDefaultAsync<T>(sql, param, commandTimeout: commandTimeout).ConfigureAwait(false); } } /// <summary> /// 执行sql返回多个对象--异步 /// </summary> /// <typeparam name="T"></typeparam> /// <param name="sql"></param> /// <param name="param"></param> /// <param name="useWriteConn"></param> /// <returns></returns> public static async Task<List<T>> ExecuteReaderRetListAsync<T>(string sql, object param = null, bool useWriteConn = false) { using (IDbConnection conn = GetConnection(useWriteConn)) { conn.Open(); var list = await conn.QueryAsync<T>(sql, param, commandTimeout: commandTimeout).ConfigureAwait(false); return list.ToList(); } } /// <summary> /// 执行sql,返回影响行数 /// </summary> /// <param name="sql"></param> /// <param name="param"></param> /// <param name="transaction"></param> /// <returns></returns> public static int ExecuteSqlInt(string sql, object param = null, IDbTransaction transaction = null) { if (transaction == null) { using (IDbConnection conn = GetConnection(true)) { conn.Open(); return conn.Execute(sql, param, commandTimeout: commandTimeout, commandType: CommandType.Text); } } else { var conn = transaction.Connection; return conn.Execute(sql, param, transaction: transaction, commandTimeout: commandTimeout, commandType: CommandType.Text); } } /// <summary> /// 执行sql,返回影响行数--异步 /// </summary> /// <param name="sql"></param> /// <param name="param"></param> /// <param name="transaction"></param> /// <returns></returns> public static async Task<int> ExecuteSqlIntAsync(string sql, object param = null, IDbTransaction transaction = null) { if (transaction == null) { using (IDbConnection conn = GetConnection(true)) { conn.Open(); return await conn.ExecuteAsync(sql, param, commandTimeout: commandTimeout, commandType: CommandType.Text).ConfigureAwait(false); } } else { var conn = transaction.Connection; return await conn.ExecuteAsync(sql, param, transaction: transaction, commandTimeout: commandTimeout, commandType: CommandType.Text).ConfigureAwait(false); } } /// <summary> /// 根据id获取实体 /// </summary> /// <typeparam name="T"></typeparam> /// <param name="id"></param> /// <param name="transaction"></param> /// <param name="useWriteConn"></param> /// <returns></returns> public static T GetById<T>(int id, IDbTransaction transaction = null, bool useWriteConn = false) where T : class { if (transaction == null) { using (IDbConnection conn = GetConnection(useWriteConn)) { conn.Open(); return conn.Get<T>(id, commandTimeout: commandTimeout); } } else { var conn = transaction.Connection; return conn.Get<T>(id, transaction: transaction, commandTimeout: commandTimeout); } } /// <summary> /// 根据id获取实体--异步 /// </summary> /// <typeparam name="T"></typeparam> /// <param name="id"></param> /// <param name="transaction"></param> /// <param name="useWriteConn"></param> /// <returns></returns> public static async Task<T> GetByIdAsync<T>(int id, IDbTransaction transaction = null, bool useWriteConn = false) where T : class { if (transaction == null) { using (IDbConnection conn = GetConnection(useWriteConn)) { conn.Open(); return await conn.GetAsync<T>(id, commandTimeout: commandTimeout); } } else { var conn = transaction.Connection; return await conn.GetAsync<T>(id, transaction: transaction, commandTimeout: commandTimeout); } } /// <summary> /// 插入实体 /// </summary> /// <typeparam name="T"></typeparam> /// <param name="item"></param> /// <param name="transaction"></param> /// <returns></returns> public static string ExecuteInsert<T>(T item, IDbTransaction transaction = null) where T : class { if (transaction == null) { using (IDbConnection conn = GetConnection(true)) { conn.Open(); var res = conn.Insert<T>(item, commandTimeout: commandTimeout); return res; } } else { var conn = transaction.Connection; return conn.Insert(item, transaction: transaction, commandTimeout: commandTimeout); } } /// <summary> /// 批量插入实体 /// </summary> /// <typeparam name="T"></typeparam> /// <param name="list"></param> /// <param name="transaction"></param> public static void ExecuteInsertList<T>(IEnumerable<T> list, IDbTransaction transaction = null) where T : class { if (transaction == null) { using (IDbConnection conn = GetConnection(true)) { conn.Open(); conn.Insert<T>(list, commandTimeout: commandTimeout); } } else { var conn = transaction.Connection; conn.Insert(list, transaction: transaction, commandTimeout: commandTimeout); } } /// <summary> /// 更新单个实体 /// </summary> /// <typeparam name="T"></typeparam> /// <param name="item"></param> /// <param name="transaction"></param> /// <returns></returns> public static bool ExecuteUpdate<T>(T item, IDbTransaction transaction = null) where T : class { if (transaction == null) { using (IDbConnection conn = GetConnection(true)) { conn.Open(); return conn.Update(item, commandTimeout: commandTimeout); } } else { var conn = transaction.Connection; return conn.Update(item, transaction: transaction, commandTimeout: commandTimeout); } } /// <summary> /// 批量更新实体 /// </summary> /// <typeparam name="T"></typeparam> /// <param name="item"></param> /// <param name="transaction"></param> /// <returns></returns> public static bool ExecuteUpdateList<T>(List<T> item, IDbTransaction transaction = null) where T : class { if (transaction == null) { using (IDbConnection conn = GetConnection(true)) { conn.Open(); return conn.Update(item, commandTimeout: commandTimeout); } } else { var conn = transaction.Connection; return conn.Update(item, transaction: transaction, commandTimeout: commandTimeout); } } /// <summary> /// 分页查询 /// </summary> /// <typeparam name="T"></typeparam> /// <param name="sql">主sql 不带 order by</param> /// <param name="sort">排序内容 id desc,add_time asc</param> /// <param name="pageIndex">第几页</param> /// <param name="pageSize">每页多少条</param> /// <param name="useWriteConn">是否主库</param> /// <returns></returns> public static List<T> ExecutePageList<T>(string sql, string sort, int pageIndex, int pageSize, bool useWriteConn = false, object param = null) { string pageSql = @"SELECT TOP {0} * FROM (SELECT ROW_NUMBER() OVER (ORDER BY {1}) _row_number_,* FROM ({2})temp )temp1 WHERE temp1._row_number_>{3} ORDER BY _row_number_"; )); using (IDbConnection conn = GetConnection(useWriteConn)) { conn.Open(); return conn.Query<T>(execSql, param, commandTimeout: commandTimeout).ToList(); } } } }
c# 封装Dapper操作类的更多相关文章
- php--->单例模式封装mysql操作类
php 单例模式封装mysql操作类 单例模式的必要条件(三私一公) 私有的成员属性--防止类外引入这个存放对象的属性 私有的构造方法--为了防止在类外使用new关键字实例化对象 私有的克隆方法--为 ...
- dapper 操作类封装
using System; using System.Collections.Generic; using System.Data; using System.Data.SQLite; using S ...
- day22:面向对象封装对象操作&类操作&面向对象删除操作
面向对象程序开发 1.类的三种定义方式 class MyClass: pass class MyClass(): #(推荐) pass class MyClass(object): # object类 ...
- c# 封装 Request操作类
/// <summary> /// 判断当前页面是否接收到了Post请求 /// </summary> /// <returns>是否接收到了Post请求</ ...
- php单例模式封装数据库操作类增删改查
<?php//三私一公 单例class Db{ //数据库连接对象 private static $instance; private static $table_name; private $ ...
- Util应用程序框架公共操作类(一):数据类型转换公共操作类(介绍篇)
本系列文章将介绍一些对初学者有帮助的辅助类,这些辅助类本身并没有什么稀奇之处,如何能发现需要封装它们可能更加重要,所谓授之以鱼不如授之以渔,掌握封装公共操作类的技巧才是关键,我会详细说明创建这些类的动 ...
- Util应用程序框架公共操作类
随笔分类 - Util应用程序框架公共操作类 Util应用程序框架公共操作类 Util应用程序框架公共操作类(五):异常公共操作类 摘要: 任何系统都需要处理错误,本文介绍的异常公共操作类,用于对业务 ...
- .net core 中简单封装Dapper.Extensions 并使用sqlsuger自动生成实体类
引言 由公司需要使用dapper 同时支持多数据库 又需要支持实体类 又需要支持sql 还需要支持事务 所以采用了 dapper + dapperExtensions 并配套 生成实体类小工具的方 ...
- c# 封装的文件夹操作类之复制文件夹
c# 封装的文件夹操作类之复制文件夹 一.复制文件夹原理: 1.递归遍历文件夹 2.复制文件 二.FolderHelper.cs /// <summary> /// 文件夹操作类 /// ...
随机推荐
- Tomcat架构解析(五)-----Tomcat的类加载机制
类加载器就是根据类的全限定名(例如com.ty.xxx.xxx)来获取此类的二进制字节流的代码模块,从而程序可以自己去获取到相关的类. 一.java中的类加载器 1.类加载器类别 java中的类加 ...
- 软件推荐-c#绘图插件echart
首先给出官网:http://echarts.baidu.com/examples/ 简单的教程:http://www.cnblogs.com/youmeng/p/4874897.html
- Chrome浏览器用AdBlockPlus拦截百度广告
一:安装AdBlockPlus插件,这个貌似要FQ安装,不知道可不可以本地安装: 二:在右侧的扩展那里找到ABP扩展,然后设置-高级-我的过滤列表栏-开始创建我的过滤列表: 三:在列表栏里添加 bai ...
- Hibernate 基础入门
概述: JDBC:将java和数据库连接的驱动程序加载到项目中,在代码里面,注册驱动,创建链接,创建satement对象,发送并执行sql之类,关闭连接. hibernate :数据持久化一个框架,对 ...
- OpenCV库框架结构
在上文已经学习过了opencv的编码规则,为了能够方便灵活的运用OPECV库,我们需要对其框架结构进行学习了解,以方便我们进行实际工程调用调用. 1.Opnecv库到底提供了什么? 打开opencv源 ...
- RxSwift学习笔记7:buffer/window/map/flatMap/flatMapLatest/flatMapFirst/concatMap/scan/groupBy
1.buffer的基本使用 let publishSubject = PublishSubject<String>() //buffer 方法作用是缓冲组合,第一个参数是缓冲时间,第二个参 ...
- Baidu WebUploader 前端文件上传组件的使用
简介 WebUploader是由Baidu WebFE(FEX)团队开发的一个简单的以HTML5为主,FLASH为辅的现代文件上传组件.在现代的浏览器里面能充分发挥HTML5的优势,同时又不摒弃主流I ...
- Python3基础语法你学会了么
编码 默认:源码文件以UTF-8编码,字符串都是unicode字符串 指定: 标识符 第一个字符:字母表中的字符或下划线 _ 其它部分:由字母.数字.下划线 _ 组成 大小写敏感 python ...
- System.Collections.Generic 源码阅读总结
ArrayList ,List ArrayList 和 List 都是不限制长度的集合类型 ,List相比ArrayList 就内部实现而言除了泛型本质没有太大区别.不过为避免装箱拆箱问题,尽可能使用 ...
- Qt之实现360安全卫士主界面代码开源
匆匆一年又过去了,总结去年一年的节奏就是忙爆了:生活忙.工作忙,值得庆幸的是没有瞎忙:今天打开博客园查看我的博客,才发现几乎差不多一年时间没写博客了:博客文章就是记忆,就是曾经努力过的见证,感谢博客园 ...