Dapper 是一个轻量级ORM框架,在项目中如果对性能比较看中,Dapper是一个不错的选择。接下来我们就来看看如何在项目中使用Dapper.

1.安装Dapper

  这里直接使用Nuget安装。

 安装完成之后,发现Nuget下已经有了Dapper。

2.创建DapperHelper

  接下来创建一个DapperHelper帮助类,来进行读取数据库连接字符串,打开数据库等操作。

代码:

  1. public class DapperHelper
  2. {
  3. /// 数据库连接名
  4. private static string _connection = string.Empty;
  5.  
  6. /// 获取连接名
  7. private static string Connection
  8. {
  9. get { return _connection; }
  10. //set { _connection = value; }
  11. }
  12.  
  13. /// 返回连接实例
  14. private static IDbConnection dbConnection = null;
  15.  
  16. /// 静态变量保存类的实例
  17. private static DapperHelper uniqueInstance;
  18.  
  19. /// 定义一个标识确保线程同步
  20. private static readonly object locker = new object();
  21. /// <summary>
  22. /// 私有构造方法,使外界不能创建该类的实例,以便实现单例模式
  23. /// </summary>
  24. private DapperHelper()
  25. {
  26. // 这里为了方便演示直接写的字符串,实例项目中可以将连接字符串放在配置文件中,再进行读取。
  27. _connection = @"server=.;uid=sa;pwd=sasasa;database=Dapper";
  28. }
  29.  
  30. /// <summary>
  31. /// 获取实例,这里为单例模式,保证只存在一个实例
  32. /// </summary>
  33. /// <returns></returns>
  34. public static DapperHelper GetInstance()
  35. {
  36. // 双重锁定实现单例模式,在外层加个判空条件主要是为了减少加锁、释放锁的不必要的损耗
  37. if (uniqueInstance == null)
  38. {
  39. lock (locker)
  40. {
  41. if (uniqueInstance == null)
  42. {
  43. uniqueInstance = new DapperHelper();
  44. }
  45. }
  46. }
  47. return uniqueInstance;
  48. }
  49.  
  50. /// <summary>
  51. /// 创建数据库连接对象并打开链接
  52. /// </summary>
  53. /// <returns></returns>
  54. public static IDbConnection OpenCurrentDbConnection()
  55. {
  56. if (dbConnection == null)
  57. {
  58. dbConnection = new SqlConnection(Connection);
  59. }
  60. //判断连接状态
  61. if (dbConnection.State == ConnectionState.Closed)
  62. {
  63. dbConnection.Open();
  64. }
  65. return dbConnection;
  66. }
  67. }

 3.创建上下文 DbContext 作用是调用Dapper中操作数据库的方法,里面是我自己封的一些常用方法,当然了这一步可以略去,直接调用也行,这里只是提供一种思路。

  1. public static class DbContext
  2. {
  3. // 获取开启数据库的连接
  4. private static IDbConnection Db
  5. {
  6. get
  7. {
  8. //创建单一实例
  9. DapperHelper.GetInstance();
  10. return DapperHelper.OpenCurrentDbConnection();
  11. }
  12. }
  13.  
  14. /// <summary>
  15. /// 查出一条记录的实体
  16. /// </summary>
  17. /// <typeparam name="T"></typeparam>
  18. /// <param name="sql"></param>
  19. /// <returns></returns>
  20. public static T QueryFirstOrDefault<T>(string sql, object param = null)
  21. {
  22. return Db.QueryFirstOrDefault<T>(sql, param);
  23. }
  24.  
  25. public static Task<T> QueryFirstOrDefaultAsync<T>(string sql, object param = null)
  26. {
  27. return Db.QueryFirstOrDefaultAsync<T>(sql, param);
  28. }
  29. /// <summary>
  30. /// 查出多条记录的实体泛型集合
  31. /// </summary>
  32. /// <typeparam name="T">泛型T</typeparam>
  33. /// <returns></returns>
  34. public static IEnumerable<T> Query<T>(string sql, object param = null, IDbTransaction transaction = null, bool buffered = true, int? commandTimeout = null, CommandType? commandType = null)
  35. {
  36. return Db.Query<T>(sql, param, transaction, buffered, commandTimeout, commandType);
  37. }
  38.  
  39. public static Task<IEnumerable<T>> QueryAsync<T>(string sql, object param = null, IDbTransaction transaction = null, int? commandTimeout = null, CommandType? commandType = null)
  40. {
  41. return Db.QueryAsync<T>(sql, param, transaction, commandTimeout, commandType);
  42. }
  43.  
  44. public static int Execute(string sql, object param = null, IDbTransaction transaction = null, int? commandTimeout = null, CommandType? commandType = null)
  45. {
  46. return Db.Execute(sql, param, transaction, commandTimeout, commandType);
  47. }
  48.  
  49. public static Task<int> ExecuteAsync(string sql, object param = null, IDbTransaction transaction = null, int? commandTimeout = null, CommandType? commandType = null)
  50. {
  51. return Db.ExecuteAsync(sql, param, transaction, commandTimeout, commandType);
  52. }
  53.  
  54. public static T ExecuteScalar<T>(string sql, object param = null, IDbTransaction transaction = null, int? commandTimeout = null, CommandType? commandType = null)
  55. {
  56. return Db.ExecuteScalar<T>(sql, param, transaction, commandTimeout, commandType);
  57. }
  58.  
  59. public static Task<T> ExecuteScalarAsync<T>(string sql, object param = null, IDbTransaction transaction = null, int? commandTimeout = null, CommandType? commandType = null)
  60. {
  61. return Db.ExecuteScalarAsync<T>(sql, param, transaction, commandTimeout, commandType);
  62. }
  63.  
  64. /// <summary>
  65. /// 同时查询多张表数据(高级查询)
  66. /// "select *from K_City;select *from K_Area";
  67. /// </summary>
  68. /// <param name="sql"></param>
  69. /// <returns></returns>
  70. public static SqlMapper.GridReader QueryMultiple(string sql, object param = null, IDbTransaction transaction = null, int? commandTimeout = null, CommandType? commandType = null)
  71. {
  72. return Db.QueryMultiple(sql, param, transaction, commandTimeout, commandType);
  73. }
  74. public static Task<SqlMapper.GridReader> QueryMultipleAsync(string sql, object param = null, IDbTransaction transaction = null, int? commandTimeout = null, CommandType? commandType = null)
  75. {
  76. return Db.QueryMultipleAsync(sql, param, transaction, commandTimeout, commandType);
  77. }
  78. }

接下来就可以调用了,DbContext.Action()

嗯。。。就写到这里吧,以后再接着写。

  1.  

.Net Core中Dapper的使用详解的更多相关文章

  1. Net Core中数据库事务隔离详解——以Dapper和Mysql为例

    Net Core中数据库事务隔离详解--以Dapper和Mysql为例 事务隔离级别 准备工作 Read uncommitted 读未提交 Read committed 读取提交内容 Repeatab ...

  2. .NET Core 中依赖注入框架详解 Autofac

    本文将通过演示一个Console应用程序和一个ASP.NET Core Web应用程序来说明依赖注入框架Autofac是如何使用的 Autofac相比.NET Core原生的注入方式提供了强大的功能, ...

  3. Asp.Net Core 中的HTTP协议详解

    1.前言 好久没写博客了,最近虽然没什么假期,但是却比以前还忙!工作.工作.工作,就像赶集似的,聚在一起.对于Web开发人员来说,深入了解HTTP有助于我们开发出更好.更高的Web应用程序.当应用程序 ...

  4. C#中的预处理指令详解

    这篇文章主要介绍了C#中的预处理指令详解,本文讲解了#define 和 #undef.#if.#elif.#else和#endif.#warning和#error.#region和#endregion ...

  5. tomcat中server.xml配置详解(转载)(一)

    转载自:https://www.cnblogs.com/starhu/p/5599773.html tomcat中server.xml配置详解 Tomcat Server的结构图如下:(该文件描述了如 ...

  6. [转帖]ASP.NET Core 中间件(Middleware)详解

    ASP.NET Core 中间件(Middleware)详解   本文为官方文档译文,官方文档现已非机器翻译 https://docs.microsoft.com/zh-cn/aspnet/core/ ...

  7. C#中string.format用法详解

    C#中string.format用法详解 本文实例总结了C#中string.format用法.分享给大家供大家参考.具体分析如下: String.Format 方法的几种定义: String.Form ...

  8. c++中vector的用法详解

    c++中vector的用法详解 vector(向量): C++中的一种数据结构,确切的说是一个类.它相当于一个动态的数组,当程序员无法知道自己需要的数组的规模多大时,用其来解决问题可以达到最大节约空间 ...

  9. 011-Scala中的apply实战详解

    011-Scala中的apply实战详解 object中的apply方法 class中的apply方法 使用方法 apply方法可以应用在类或者Object对象中 class类 必须要创建实例化的类对 ...

随机推荐

  1. Mac上重置mysql 5.7密码

    Mac上重置mysql 5.7密码 >我的mac系统是osx 10.12 装完mysql5.7之前根本登录不上,网上说用DMG方式装完后,后弹出一个框,上面会有临时密码,但是我安装的时候却手一抖 ...

  2. 记录MYSQL中SQL语句的一个坑.

    MYSQL5.7 假设我们有一个表 : h_member_cards_my  (ID, WXOPEN_ID) 表中有一条记录如下: 理论上第二个SQL应当是可以查询得到一条数据的, 结果却为 Empt ...

  3. Python之copy模块

    概念 官方解释:Python中的赋值语句不复制对象,它们在目标和对象之间建立索引.对于可变项目或可变项目的集合,有时需要一个副本,以便可以更改一个副本而不更改其他副本.该模块提供通用的浅层和深层cop ...

  4. [转]CDH QuickStart VM基本使用

    https://blog.csdn.net/wiborgite/article/details/78731944 https://www.cnblogs.com/harrychinese/p/big_ ...

  5. 利用easygui模块编写的华氏温度与摄氏温度转换的小程序

    -*- coding:utf-8 -*- #Author:'Lmc' #DATE: 2019/4/23/0023 下午 4:23:08 #FileName:tem_compare_gui.PY imp ...

  6. SpringBoot使用ELK日志收集

    本文介绍SpringBoot应用配合ELK进行日志收集. 1.有关ELK 1.1 简介 在之前写过一篇文章介绍ELK日志收集方案,感兴趣的可以去看一看,点击这里-----> <ELK日志分 ...

  7. Stream闪亮登场

    Stream闪亮登场 一. Stream(流)是什么,干什么 Stream是一类用于替代对集合操作的工具类+Lambda式编程,他可以替代现有的遍历.过滤.求和.求最值.排序.转换等 二. Strea ...

  8. Spring Cloud项目MVN编译 -- Non-resolvable import POM

    最近利用闲余时间,打算搭建一套基于Spring Cloud G版的微服务架构(Spring boot 2.1.0),一顿操作之后,IDEA也没有提示什么错误,自认为微服务搭建完毕.启动项目前,习惯性的 ...

  9. MyBatis3系列__06查询的几点补充

    关于查询的一点补充: 当查询部门信息时,希望查询该部门下的所有员工,下面会采取两种方式实现: 1.联合查询 public Department getDeptWithEmpById(Integer i ...

  10. Python爬虫开发与项目实战

    Python爬虫开发与项目实战(高清版)PDF 百度网盘 链接:https://pan.baidu.com/s/1MFexF6S4No_FtC5U2GCKqQ 提取码:gtz1 复制这段内容后打开百度 ...