Slapper帮助Dapper实现一对多
Dapper的Query的方法提供了多个泛型重载可以帮助我们实现导航属性的查询
1对1
public class Employees4List
{
public int Id { get; set; }
public string Name { get; set; }
public string Mobile { get; set; }
public Department4Employees Department { get; set; }
}
public class Role4Employees
{
public int Id { get; set; }
public string Name { get; set; }
}
IEnumerable<Employees4List> GetEmployees()
{
var sql = $@"
select #e.[Id],#e.[Name],#e.[Mobile]
,#depart.id,#depart.name
from dbo.T_Eemploye #e
left join [dbo].[T_Department] #depart on #depart.id = #e.Department
";
using (var conn = GetReadConnection())
{
var list = conn.Query<Employees4List, Department4Employees, Employees4List>(sql, (e, d) =>
{
e.Department = d;
return e;
});
return list;
}
}
1对n
但是如果职工类中加入这样一个属性呢 ? public List<Role4Employees> Role { get; set; }
public class Employees4List
{
public int Id { get; set; }
public string Name { get; set; }
public string Mobile { get; set; }
public List<Role4Employees> Role { get; set; }
public Department4Employees Department { get; set; }
}
public class Role4Employees
{
public int Id { get; set; }
public string Name { get; set; }
}
public class Department4Employees
{
public int Id { get; set; }
public string Name { get; set; }
}
之前看到过这样一个方式,但是它是不能像我们想象的那样工作,这里如果一个Eemploye有多个角色,那就和原始的sql语句一样,他会产生重复的记录
IEnumerable<Employees4List> GetEmployees()
{
var sql = $@"
select #e.[Id],#e.[Name],#e.[Mobile]
,#depart.id,#depart.name
,#role.id,#role.name
from dbo.T_Eemploye #e
left join [dbo].[T_Department] #depart on #depart.id = #e.Department
left join [dbo].[T_Role] #role on #role.value & #e.role = #role.value
";
using (var conn = GetReadConnection())
{
var list = conn.Query<Employees4List, Department4Employees, Role4Employees, Employees4List>(sql,(e, d, r) =>
{
e.Department = d;
e.Role.Add(r);
return e;
});
return list;
}
}
正确的方式是使用Slapper.Automapper,这个包需要独立安装
IEnumerable<Employees4List> GetEmployees()
{
var sql = $@"
select #e.[Id],#e.[Name],#e.[Mobile]
,#role.id Role_Id,#role.name Role_Name
,#depart.id Department_Id,#depart.name Department_Name
from dbo.T_Eemploye #e
left join [dbo].[T_Role] #role on #role.value & #e.role = #role.value
left join [dbo].[T_Department] #depart on #depart.id = #e.Department
";
using (var conn = GetReadConnection())
{
var dynamic = conn.Query<dynamic>(sql); Slapper.AutoMapper.Configuration.AddIdentifiers(typeof(Employees4List), new List<string> { "Id" });
Slapper.AutoMapper.Configuration.AddIdentifiers(typeof(Role4Employees), new List<string> { "Id" });
Slapper.AutoMapper.Configuration.AddIdentifier(typeof(Department4Employees), "Id"); var list = (Slapper.AutoMapper.MapDynamic<Employees4List>(dynamic) as IEnumerable<Employees4List>).ToList(); return list;
}
}
通过AddIdentifier和AddIdentifier来识别外键是1对1还是1对n,需要注意的是这里需要对字段取别名,怎么取呢?
新的名称以在c#类中字段名称+下划线+导航类的字段名称
比如说Employees4List中有一个属性Role要做1对n查询,通过AddIdentifiers方法指明需要转换的类型名称和主键名称,其次在sql语句中通过
Role_Id和Role_Name来取别名,下划线前面的Role来自Employees4List的 Role属性,下划线后面的 Id 和 Name来自 Role4Employees
Slapper帮助Dapper实现一对多的更多相关文章
- Dapper实现一对多对象关系聚合导航属性
领域对象:Game(游戏), Room(游戏群),两者一对多的关系,SQL语句中会用到JOIN public class Game : AggregateRoot { public string Ta ...
- 三层架构的一点理解以及Dapper一对多查询
1.首先说一下自己对三层架构的一点理解 论坛里经常说会出现喜欢面相对象的写法,所以使用EF的,我个人觉得他俩没啥关系,先别反对,先听听我怎么说吧. 三层架构,基本都快说烂了,但今天还是说三层架构:UI ...
- Dapper 一对多查询 one to many
参考文档:Dapper one to many Table public class Person { public int Id { get; set; } public string Name { ...
- Dapper.NET——轻量ORM
Dapper.NET使用 http://www.cnblogs.com/yankliu-vip/p/4182892.html 本文目录 Dapper.NET使用 1.为什么选择Dapper 2.以Da ...
- Dapper.Net 应用
Dapper应用 1.Dapper是什么 Dapper是一款轻量级ORM工具.如果你在小的项目中,使用Entity Framework.NHibernate 来处理大数据访问及关系映射,未免有点杀鸡用 ...
- ORM系列之三:Dapper
目录 1.Dapper 简介 2.Dapper 安装 3.Dapper 使用 Dapper简介 Dapper是一个轻量级的ORM框架,短小精悍,正如其名.对于小项目,使用EF,NHibernate这样 ...
- Dapper
前一段做一个技术分享关于dapper的,现在再总结一下,也好长时间没有更新博客了--,用到的东西 Dapper.AutoFac .AutoMapper.FluentValidation: 下面说一下D ...
- Dapper学习笔记(1)-开始
Dapper是一款开源的轻量级ORM工具,源代码下载地址为https://github.com/StackExchange/dapper-dot-net,其具有以下特点: 1.Dapper是一个轻型的 ...
- 轻型的ORM类Dapper
Dapper是一个轻型的ORM类.代码就一个SqlMapper.cs文件,主要是IDbConnection的扩展方法,编译后就40K的一个很小的dll.官方站点http://code.google.c ...
随机推荐
- 【网络】高性能网络编程--下一个10年,是时候考虑C10M并发问题了
转载:http://www.52im.net/thread-568-1-1.html 1.前言 在本系列文章的上篇中我们回顾了过云的10年里,高性能网络编程领域著名的C10K问题及其成功的解决方案(上 ...
- SQL Server2012 配置管理器无法打开
由于需要电脑上装了 SQLServer 2008 R2 和 SQLServer 2012 两个版本的数据库,两个库的实例名称不一样,之前一直用实例名连接对应的数据库,正常没有问题.现在用 “ip+端口 ...
- Spark机器学习(4):朴素贝叶斯算法
1. 贝叶斯定理 条件概率公式: 这个公式非常简单,就是计算在B发生的情况下,A发生的概率.但是很多时候,我们很容易知道P(A|B),需要计算的是P(B|A),这时就要用到贝叶斯定理: 2. 朴素贝叶 ...
- golang 面向对象编程
概述 Golang语言的面向对象与c++,py等语言有所不同,是由于Golang不支持继承:与上述支持聚合和继承的面向对象的语言不同,Golang只支持聚合(也叫做组合)和嵌入.聚合和嵌入的区别: t ...
- synchronized和lock比较
一.synchronized的实现方案 1.synchronized能够把任何一个非null对象当成锁,实现由两种方式: a.当synchronized作用于非静态方法时,锁住的是当前对象的事例,当s ...
- PySpark 的背后原理
文章正文 Spark主要是由Scala语言开发,为了方便和其他系统集成而不引入scala相关依赖,部分实现使用Java语言开发,例如External Shuffle Service等.总体来说,Spa ...
- Gradle环境变量的配置
配置GRADLE_HOME: 找到Android Studio中gradle的位置 E:\Android_Studio\gradle\gradle-2.10 配置GRADLE_USER_HOME: 找 ...
- FragmentPagerAdapter 与 FragmentStatePagerAdapter 的区别
参考链接: http://blog.csdn.net/dreamzml/article/details/9951577 简单来说前者适合静态.少量的Fragment 后者适合动态.较多的Fragmen ...
- python中的ord函数
chr().unichr()和ord() chr()函数用一个范围在range(256)内的(就是0-255)整数作参数,返回一个对应的字符.unichr()跟它一样,只不过返回的是Unicode字符 ...
- iOS开发微信支付
现在基本所有的App都会接入支付宝支付以及微信支付,也有很多第三方提供给你 SDK帮你接入,但是这种涉及到支付的东西还是自己服务器搞来的好一些,其实搞懂了 逻辑非常的简单,下面直接给大家说说下基本流程 ...