轻量级高性能ORM框架:Dapper高级玩法
Dapper高级玩法1:
数据库中带下划线的表字段自动匹配无下划线的Model字段。
备注:
这个对使用Mysql数据库的朋友最有帮助,因为Mysql默认都是小写,一般字段都带下划线,比如:user_name之类。
具体效果如下演示
1,首先创建一张表并插入数据

2,创建Model模型
public class User
{
public int UserID { get; set; } public string UserName { get; set; } public int RoleID { get; set; }
}
3,扩写抽取数据逻辑代码.
select * from [user]
static Program()
{
var config = new ConfigurationBuilder()
.SetBasePath(Directory.GetCurrentDirectory())
.AddJsonFile("appsettings.json", optional: true, reloadOnChange: true); var data = config.Build();
DapperExtension.DBConnectionString = data.GetConnectionString("DefaultConnection");
} static void Main(string[] args)
{
IDbConnection dbconnection = null; using (dbconnection = dbconnection.OpenConnection())
{
var users = dbconnection.List("select * from [user]", null);
foreach (var user in users)
{
Console.WriteLine($"{user.UserID}-{user.UserName}-{user.RoleID}");
}
} Console.ReadKey();
}
4,无MatchNamesWithUnderscores设置时的数据抽取

没有绑定成功??
这是因为用了Select * from的缘故,取出来的字段是带下划线的与Model的字段不匹配。
5,设置MatchNamesWithUnderscores再次数据抽取
static void Main(string[] args)
{
Dapper.DefaultTypeMap.MatchNamesWithUnderscores = true;
IDbConnection dbconnection = null;
using (dbconnection = dbconnection.OpenConnection())
{
var users = dbconnection.List("select * from [user]", null);
foreach (var user in users)
{
Console.WriteLine($"{user.UserID}-{user.UserName}-{user.RoleID}");
}
} Console.ReadKey();
}

数据绑定成功。
就一句Dapper.DefaultTypeMap.MatchNamesWithUnderscores = true,让我们少写了不少AS语句。
Dapper高级玩法2:
法力无边的Query,由于带有Function功能,可以自由设置模型绑定逻辑。
1,创建两张有关联的表,并填入数据。


2,抽取user和它关联的role数据。
select 1 as table1,T1.*,1 as table2,T2.* from [user] T1 inner join [role] T2 on T1.role_id = T2.role_id
扩展方法:
public static IEnumerable QueryT(this IDbConnection dbconnection, string sql, Func map, object param = null, IDbTransaction transaction = null, string splitOn = "Id")
{
return dbconnection.Query(sql, map, param, transaction, splitOn: splitOn);
}
使用:
static void QueryTest()
{
Dapper.DefaultTypeMap.MatchNamesWithUnderscores = true;
IDbConnection dbconnection = null;
using (dbconnection = dbconnection.OpenConnection())
{
var result = dbconnection.QueryT(
@"select 1 as table1,T1.*,1 as table2,T2.* from [user] T1 inner join [role] T2 on T1.role_id = T2.role_id",
(user, role) =>
{
user.Role = role;
return user;
},
null,
splitOn: "table1,table2"); foreach (var user in result)
{
Console.WriteLine($"{user.UserID}-{user.UserName}-{user.Role.RoleID}-{user.Role.RoleName}");
}
}
Console.ReadKey();
}

成功取到数据。
splitOn解释:模型绑定时的字段分割标志。table1到table2之间的表字段绑定到User,table2之后的表字段绑定到Role。
3,特殊Function逻辑。比如抽取role_id对应的user一览。
select 1 as table1,T1.*,1 as table2,T2.* from [role] T1 left join [user] T2 on T1.role_id = T2.role_id
外部定义了一个字典类型,Query内部模型绑定的时候每次调用Function函数,Function函数中将数据添加到外部字典中,这在复杂数据处理时很有用。
static void QueryTest2()
{
Dapper.DefaultTypeMap.MatchNamesWithUnderscores = true;
IDbConnection dbconnection = null;
using (dbconnection = dbconnection.OpenConnection())
{
Dictionary> dic = new Dictionary>(); dbconnection.QueryT(
@"select 1 as table1,T1.*,1 as table2,T2.* from [role] T1 left join [user] T2 on T1.role_id = T2.role_id",
(role, user) =>
{
if (dic.ContainsKey(role.RoleID))
{
dic[role.RoleID].Add(user);
}
else
{
dic.Add(role.RoleID, new List { user });
} return true;
},
null,
splitOn: "table1,table2"); foreach (var data in dic)
{
Console.WriteLine($"role:{data.Key}");
foreach (var user in data.Value)
{
Console.WriteLine($"user:{user.UserID}-{user.UserName}");
}
}
}
Console.ReadKey();
}
输出结果:

今天就介绍到这,后续有时间再添加其他的玩法,个人比较喜好Dapper这种自由的写法。
轻量级高性能ORM框架:Dapper高级玩法的更多相关文章
- .NET轻量级ORM框架Dapper入门精通
一.课程介绍 本次分享课程包含两个部分<.NET轻量级ORM框架Dapper修炼手册>和<.NET轻量级ORM框架Dapper葵花宝典>,阿笨将带领大家一起领略轻量级ORM框架 ...
- 【ASP.NET Core】依赖注入高级玩法——如何注入多个服务实现类
依赖注入在 ASP.NET Core 中起中很重要的作用,也是一种高大上的编程思想,它的总体原则就是:俺要啥,你就给俺送啥过来.服务类型的实例转由容器自动管理,无需我们在代码中显式处理. 因此,有了依 ...
- 【Python基础】random 的高级玩法
random 模块的高级玩法 1.python 随机产生姓名 方式一: import random xing = [ '赵', '钱', '孙', '李', '周', '吴', '郑', '王', ' ...
- Word 查找替换高级玩法系列之 -- 段首批量添加字符
打开「查找和替换」输入框,按照下图操作: 更多查找替换高级玩法,参看:Word查找替换高级玩法系列 -- 目录篇 未完 ...... 点击访问原文(进入后根据右侧标签,快速定位到本文)
- Word 查找替换高级玩法系列之 -- 把论文中的缩写词快速变成目录下边的注释表
1. 前言 问题:Word写论文如何把文中的缩写快速转换成注释表? 原来样子: 想要的样子: 2. 步骤 使用查找替换高级用法,替换缩写顺序 选中所有文字 打开查找替换对话框,输入以下表达式: 替换后 ...
- maven 高级玩法
maven 高级玩法 标签(空格分隔): maven 实用技巧 Maven 提速 多线程 # 用 4 个线程构建,以及根据 CPU 核数每个核分配 1 个线程进行构建 $ mvn -T 4 clean ...
- c# 国内外ORM 框架 dapper efcore sqlsugar freesql hisql sqlserver数据常规插入测试性能对比
c# 国内外ORM 框架 dapper efcore sqlsugar freesql hisql sqlserver数据常规插入测试性能对比对比 在6.22 号发布了 c# sqlsugar,his ...
- 轻量级ORM框架Dapper应用一:Dapper安装
一.Dapper简介 Dapper是一款轻量级ORM框架,为解决网站访问流量极高而产生的性能问题而构造,主要通过执行TSQL表达式而实现数据库的CQRS. 如果你在项目中遇到性能访问问题,选择Dapp ...
- 高性能ORM 框架之 MySqlSugar
mysql 3.X API地址: http://www.cnblogs.com/sunkaixuan/p/5987308.html MySqlSugar 1.5 API 一.介简 SqlSugar ...
随机推荐
- PyCharm的小技巧
PyCharm是一种Python IDE,带有一整套可以帮助用户在使用Python语言开发时提高其效率的工具,比如:代码跳转.智能提示.自动完成.单元测试.版本控制.此外,该IDE提供了一些高级功能, ...
- 【转】一分钟内检查Linux服务器性能
近期看了一篇运维排查的问题的十条命令,仔细看了一下,发现就是自己平时经常使用的一些,感觉还不错,就转一发~分享学习~ 如果你的Linux服务器突然负载暴增,告警短信快发爆你的手机,如何在最短时间内找出 ...
- Samba文件共享服务
Samba起源: 早期网络想要在不同主机之间共享文件大多要用FTP协议来传输,但FTP协议仅能做到传输文件却不能直接修改对方主机的资料数据,这样确实不太方便,于是便出现了NFS开源文件共享程序:NFS ...
- java 线程方法join的简单总结
虽然关于讨论线程join方法的博客已经很多了,不过个人感觉挺多都讨论得不够全面,所以我觉得有必要对其进行一个全面的总结. 一.作用 Thread类中的join方法的主要作用就是同步,它可以使得线程之间 ...
- Easy machine learning pipelines with pipelearner: intro and call for contributors
@drsimonj here to introduce pipelearner – a package I'm developing to make it easy to create machine ...
- glmnetUtils: quality of life enhancements for elastic net regression with glmnet
The glmnetUtils package provides a collection of tools to streamline the process of fitting elastic ...
- javascript中break和continue的区别
1.break:跳出循环. 2.continue:跳过循环中的一个迭代.(迭代:重复反馈过程的滑动,其目的是为了逼近所需目标或结果.每一次对过程的重复称为一次"迭代",而每一次迭代 ...
- 从零开始的JS生活(三)——内置对象
咱们继续进行我们的正经的JS介绍.今天所要跟大家讲述的是JS中十分常用.十分常用.十分常用的内置对象. 一.世界上最熟悉的陌生就是,当你看着数组.而我看着你... - 数组对象 1.数组的概念 在内存 ...
- Java经典编程题50道之十八
两个乒乓球队进行比赛,各出三人.甲队为a,b,c三人,乙队为x,y,z三人,以抽签决定比赛名单.有人向队员打听比赛的名单:a说他不和x比,c说他不和x. z比.请编程序找出三队赛手的名单. publi ...
- linux下部署php项目-Apache、php、mysql关联
linux下部署php项目环境可以分为两种,一种使用Apache,php,mysql的压缩包安装,一种用yum命令进行安装. 使用三种软件的压缩包进行安装,需要手动配置三者之间的关系.apache和p ...