目录

1.多表联合查询

默认情况下Where,Get,ToList,PageList等函数只支持单表操作,

var comment = conn.QuerySet<Comment>()
                     .Where(x => x.Id.NotIn(new int[] { 1, 2, 3 })
&& x.SubTime.AddMinutes(50) < DateTime.Now.AddDays(-1)
&& x.Type.IsNotNull())
                     .ToList(); 

3.1.2后支持双表和三表同时映射操作,需要通过From函数指定映射表,

 var comment = conn.QuerySet<Comment>()
.From<Comment, News, ResourceMapping>()
.Where((a, b, c) => a.Id == 1
&& b.Headlines.IsNotNull()
&& c.RSize > 100);

也可以通过GetQuerySet()返回基础的QuerySet对象

var comment = conn.QuerySet<Comment>()
.From<Comment, News, ResourceMapping>()
.Where((a, b, c) => a.Id == 1
&& b.Headlines.IsNotNull()
&& c.RSize > 100)
.GetQuerySet()
.ToList();

以上是三表联合查询,如果有更多表联合需求可以通过自己扩展实现,

    /// <summary>
/// 定义一个四表联合扩展类
/// </summary>
/// <typeparam name="T">对应QuerySet的泛型</typeparam>
/// <typeparam name="T1">扩展泛型1</typeparam>
/// <typeparam name="T2">扩展泛型2</typeparam>
/// <typeparam name="T3">扩展泛型3</typeparam>
/// <typeparam name="T4">扩展泛型4</typeparam>
public class testFrom<T, T1, T2, T3,T4> : ISelect<T>
{
public testFrom(QuerySet<T> querySet) : base(querySet)
{ }
//定义了一个Where
public testFrom<T, T1, T2, T3,T4> Where(Expression<Func<T1, T2, T3,T4, bool>> select)
{
base.Where(select);
return this;
}
//定义了一个ToList
public IEnumerable<TReturn> ToList<TReturn>(Expression<Func<T1, T2, T3,T4, TReturn>> select)
{
return base.ToList<TReturn>(select);
}
}

  然后使用扩展类

                //首先声明一个QuerySet
var querySet = conn.QuerySet<Comment>();
/*把定义的querySet实例带入到扩展类中
(注意:第一个T类型必须对应querySet的泛型,如Comment)*/
var list = new testFrom<Comment, Comment, News, ResourceMapping, LikeRecord>(querySet)
.Where((a, b, c, d) => a.Id == 1
&& b.NewsLabel.Contains("t"))
.GetQuerySet()
.ToList();

  

以此类推,可以任意扩展联表的数量

以下是支持的函数

public class ISelect<T>
{
public ISelect(QuerySet<T> querySet); public TReturn Get<TReturn>(LambdaExpression exp);
public QuerySet<T> GetQuerySet();
public ISelect<T> OrderBy<TProperty>(Expression<Func<TProperty, object>> field);
public ISelect<T> OrderByDescing<TProperty>(Expression<Func<TProperty, object>> field);
public PageList<TReturn> PageList<TReturn>(int pageIndex, int pageSize, LambdaExpression exp);
public IEnumerable<TReturn> ToList<TReturn>(LambdaExpression exp);
public QuerySet<T> Where(LambdaExpression exp);
}

  

2.结果返回匿名类型

3.12版本后支持返回匿名类型,

  var comment = conn.QuerySet<Comment>()
.Where(x => x.Content == "test1" && x.Content.Contains("t"))
.Get(x => new
{
Id = 123,
ArticleId = x.ArticleId
});

一些复杂的字段返回可以通过sql实现,

例如

var comment = conn.QuerySet<Comment>()
.Join<Comment, News>((a, b) => a.ArticleId == b.Id)
.Where(x => x.Content == "test1" && x.Content.Contains("t"))
.Where<Comment, News>((a, b) => a.SubTime < DateTime.Now.AddDays(-5) && a.Id > a.Id % 1)
.Get(x => new
{
count = Convert.ToInt32("(select count(1) from Comment_4)"),
aaa = "6666",
});

并且也支持联合查询的返回

var comment = conn.QuerySet<Comment>()
.Join<Comment, News>((a, b) => a.ArticleId == b.Id)
.Join<Comment, ResourceMapping>((a, b) => a.Id == b.FKId)
.Where(x => x.Content == "test")
.From<Comment, News, ResourceMapping>()
.OrderBy<News>(x => x.Id)
.Where((a, b, c) => a.ArticleId == b.Id)
.PageList(1, 10, (a, b, c) => new
{
id = a.Id,
name = b.NewsLabel,
resource = c.RPath,
rownum = Convert.ToInt32("ROW_NUMBER() OVER(ORDER BY Comment.Id)"),
NewsLable = "News.NewsLabel"
});

还支持比较复杂的子查询

子查询支持的函数有  Count()  Sum<T>(字段)

例如

var comment1 = conn.QuerySet<Comment>()
.Join<Comment, News>((a, b) => a.ArticleId == b.Id)
.Where(x => x.Id.Between(80, 100)
&& x.SubTime.AddDays(-10) < DateTime.Now && x.Id > 10)
.From<Comment, News>()
.Get((a, b) => new
{
//(不查询数据库的方法可以任意使用)
test = new List<int>() { 3, 3, 1 }.FirstOrDefault(y => y == 1),
aaa = "6666" + "777",
Content = a.Content + "'test'" + b.Headlines + a.IdentityId,
//此字段会拼接成子查询,不用担心循环查询造成的性能问题
bbb = new QuerySet<Comment>(conn, new MySqlProvider())
.Where(y => y.ArticleId == b.Id && y.Content.Contains("test")).Sum<Comment>(x => x.Id),
ccc = a.IdentityId,
ddd = Convert.ToInt32("(select count(1) from Comment)")
});

  

完整Demo可以去Github上下载:

https://github.com/a935368322/Kogel.Dapper.Test

如有问题也可以加QQ群讨论:

技术群 710217654

框架开源,可以加群下载源码

[LINQ2Dapper]最完整Dapper To Linq框架(六)---多表联合与匿名类型返回的更多相关文章

  1. [LINQ2Dapper]最完整Dapper To Linq框架(七)---仓储模式

    目录 [LINQ2Dapper]最完整Dapper To Linq框架(一)---基础查询 [LINQ2Dapper]最完整Dapper To Linq框架(二)---动态化查询 [LINQ2Dapp ...

  2. [LINQ2Dapper]最完整Dapper To Linq框架(一)---基础查询

    此例子是使用LINQ2Dapper封装,效率优于EntityFramwork,并且支持.NetFramework和.NetCore框架,只依赖于Dapper 支持.net framework4.5.1 ...

  3. [LINQ2Dapper]最完整Dapper To Linq框架(二)---动态化查询

    目录 [LINQ2Dapper]最完整Dapper To Linq框架(一)---基础查询 [LINQ2Dapper]最完整Dapper To Linq框架(二)---动态化查询 [LINQ2Dapp ...

  4. [LINQ2Dapper]最完整Dapper To Linq框架(三)---实体类关系映射

    此特性需要安装Kogel.Dapper.Mssql或者Oracle 3.06及以上版本,实体类层需要安装Kogel.Dapper.Extension 3.06及以上版本 目录 [LINQ2Dapper ...

  5. [LINQ2Dapper]最完整Dapper To Linq框架(四)---Linq和SQL并行使用

    目录 [LINQ2Dapper]最完整Dapper To Linq框架(一)---基础查询 [LINQ2Dapper]最完整Dapper To Linq框架(二)---动态化查询 [LINQ2Dapp ...

  6. [LINQ2Dapper]最完整Dapper To Linq框架(五)---查看Linq实际执行的SQL

    此例子是使用LINQ2Dapper封装,效率优于EntityFramwork,并且支持.NetFramework和.NetCore框架,只依赖于Dapper支持.net framework4.6.1及 ...

  7. [LINQ2Dapper]最完整Dapper To Linq框架(八)---导航属性

    目录 [LINQ2Dapper]最完整Dapper To Linq框架(一)---基础查询 [LINQ2Dapper]最完整Dapper To Linq框架(二)---动态化查询 [LINQ2Dapp ...

  8. Linq To Sql多表联合查询

    var pro = (from ps in db.ProductInfoes join pt in db.ProductTypees on ps.productType equals pt.pType ...

  9. 基于springboot+bootstrap+mysql+redis搭建一套完整的权限架构【六】【引入bootstrap前端框架】

    https://blog.csdn.net/linzhefeng89/article/details/78752658 基于springboot+bootstrap+mysql+redis搭建一套完整 ...

随机推荐

  1. 8 个 Python 实用脚本,【速】收藏备用!

    脚本写的好,下班下得早!程序员的日常工作除了编写程序代码,还不可避免地需要处理相关的测试和验证工作. 例如,访问某个网站一直不通,需要确定此地址是否可访问,服务器返回什么,进而确定问题在于什么.完成这 ...

  2. 第10项:重写equals时请遵守通用约定

      重写equals方法看起来似乎很简单,但是有许多重写方式会导致错误,而且后果非常严重.最容易避免这类问题的办法就是不覆盖equals方法,在这种情况下,类的每个实例都只能与它自身相等.如果满足了以 ...

  3. Oracle VM VirtualBOX桥接网卡

    1.在VirtualBOX设置中的网络菜单,连接方式选择桥接网卡 2.启动系统,设置静态IP sudo vim /etc/network/interfaces auto enp0s3         ...

  4. DJango配置mysql数据库以及数据库迁移

    DJango配置mysql数据库以及数据库迁移 一.Django 配置MySQL数据库 在settings.py中配置 import pymysql # 配置MySQL pymysql.install ...

  5. Web安全之CSRF漏洞整理总结

    这两天整理和编写了csrf的靶场,顺便也复习了以前学习csrf的点,这里记录下学习的总结点. 0x01 关于CSRF 跨站请求伪造 CSRF(Cross-site request forgery)跨站 ...

  6. 百万年薪python之路 -- 异常处理

    异常处理 1.错误的分类: 1.语法错误:(这种错误,根本过不了python解释器的语法检测,必须在程序执行前就改正) #语法错误示范一 if #语法错误示范二 def test: pass #语法错 ...

  7. Servlet处理原生Ajax请求

    萌新小白人生中的第一篇博客,难免会有差错,还望各位大佬多多包涵. 1. Ajax技术简介      Ajax(Asynchronous JavaScript and XML,异步JavaScript和 ...

  8. JavaWeb 如何防止表单重复提交 - 使用Token,令牌

    JavaWeb 如何防止表单重复提交 - 使用Token,令牌 说到重复提交 ,应该想到两种场景:1. 在下单,或者支付 这种情况 那么不允许  刷新,不允许后退再点击提交(后退之后提交会失败,修改了 ...

  9. JVM(6) 字节码执行引擎

    编译器(javac)将Java源文件(.java文件)编译成Java字节码(.class文件). 类加载器负责加载编译后的字节码,并加载到运行时数据区(Runtime Data Area) 通过类加载 ...

  10. 什么是Viewport

    什么是Viewport 手机浏览器是把页面放在一个虚拟的“窗口”(viewport)中,通常这个虚拟的“窗口”(viewport)比屏幕宽,这样就不用把每个网页挤到很小的窗口中(这样会破坏没有针对手机 ...