转眼一看,又过了10几天没有写博客了,主要还是没有什么可以写的,因为遇到的问题都不是很有价值。不过最近发现用lambda表达式,比用Linq的代码量会少一些,而且也方便一些。不过两者都差不多,相差不是特别大。

在EF core中,表和表之中都有对应的关系,例如一对一,一对多,还有多对多。要实现一对一,一对多加上主外键,实现多对多则需要加上一个中间表,这样结构清晰,维护也非常的方便。

那我们在使用EF core 势必要用到非常多的跨表查询,来看看linq是怎样查找数据库中的信息的:

var query = from a in db.ExaminationOrderInfo
join b in db.ExaminationOrganization on a.OrganizationId equals b.OrganizationId
join c in db.Customerinfo on a.CustomerId equals c.CustomerId
join d in db.Supplierinfo on a.OrganizationId equals d.OrganizationId
where (a.IsDelete == )
&& (appointmentResult == null || a.AppointmentResult == appointmentResult)
&& (isPaperReport == null || a.IsPaperReport == isPaperReport)
&& (examinationStatus == null || a.ExaminationStatus == examinationStatus)
&& (name == null || a.Name == name)
&& (id == null || a.IdCard == id)
&& (organizationName == null || b.Name == organizationName)
&& (customer == null || c.Name == customer)
&& (supplierName == null || d.Name == supplierName)
orderby a.AppayTime
select new ExaminationOrderInfoDto
{
Type = a.Type == ? "取消预约" : "预约",
IdCard = a.IdCard,
Name = a.Name,
StartTime = a.StartTime.ToString(),
EndTime = a.EndTime.ToString(),
AppayTime = a.AppayTime,
ExaminationTime = a.ExaminationTime.ToString(),
AppointmentResult = a.AppointmentResult == ? "成功" : a.AppointmentResult == ? "失败" : "待处理",
ExaminationStatus = a.ExaminationStatus == ? "已登记" : "未登记",
IsPaperReport = a.IsPaperReport == ? "已打印" : "未打印",
ElectronicReport = a.ElectronicReport,
Organization = b.Name,
Customer = c.Name,
SupplierName = d.Name
};

可以看出连接了三张表去查询也就是 join....on.... ,然后加上排序,这样代码会偏多一点。

那么我们来看看使用lambda表达式会怎么样:

 var query = db.ExaminationOrderInfo.Where(e => e.IsDelete ==
&& (appointmentResult == null || e.AppointmentResult == appointmentResult)
&& (isPaperReport == null || e.IsPaperReport == isPaperReport)
&& (examinationStatus == null || e.ExaminationStatus == examinationStatus)
&& (string.IsNullOrEmpty(name) || e.Name == name)
&& (string.IsNullOrEmpty(customer) || e.Customerinfo.Name == customer)
&& (string.IsNullOrEmpty(id) || e.IdCard == id)
&& (string.IsNullOrEmpty(organizationName) || e.ExaminationOrganization.Name == organizationName)
&& (string.IsNullOrEmpty(supplierName) || e.ExaminationOrganization.SupplierInfo.Name == supplierName)).Select(e => new ExaminationOrderInfoDto
{
Type = e.Type == ? "取消预约" : "预约",
IdCard = e.IdCard,
Name = e.Name,
Expire = DateTime.Now > e.ExaminationTime ? "是" : "否",
StartTime = e.StartTime.ToString(),
EndTime = e.EndTime.ToString(),
AppayTime = e.AppayTime,
ExaminationTime = e.ExaminationTime.ToString(),
AppointmentResult = e.AppointmentResult == ? "成功" : e.AppointmentResult == ? "失败" : "待处理",
ExaminationStatus = e.ExaminationStatus == ? "已登记" : "未登记",
IsPaperReport = e.IsPaperReport == ? "已打印" : "未打印",
ElectronicReport = e.ElectronicReport,
Organization = e.ExaminationOrganization.Name,
Customer = e.Customerinfo.Name,
SupplierName = e.ExaminationOrganization.SupplierInfo.Name
}).OrderBy(e => e.AppayTime);

我们可以看到使用lambda表达式就没有太多的连接代码了,如果想要查询的话,直接就e.Customerinfo.Name 可以得到Customerinfo表的name了,这是为什么呢,因为ExaminationOrderInfo这个实体中有这个字段:

 public Customerinfo Customerinfo { get; set; }

这就将ExaminationOrderInfo和Customerinfo连接起来了,一个ExaminationOrderInfo对应一个Customerinfo,而相信大家也留意到了ExaminationOrganization这个表了,里面对应的关系是这样的:

public ICollection<ExaminationOrderInfo> ExaminationOrderInfo { get; set; }

也就是说一个ExaminationOrganization对应多个ExaminationOrderInfo。那么还有 e.ExaminationOrganization.SupplierInfo.Name,为何需要这样呢,是因为ExaminationInfo是通过ExaminationOrganization这张表和Supplier连接的。

相信大家已经清楚了这两张查询方式的不同,建议大家两种都去了解和熟悉,这样遇到问题的时候有多种思考方式,不过我一般建议大家用lambda表达式,这样代码非常简洁,易读性也较高。

最后,有什么错误请指出,互相学习。谢谢大家!

EF core 中用lambda表达式和Linq的一些区别的更多相关文章

  1. entity framework 新手入门篇(1.5)-lambda表达式与linq

    在建立好了EF模型之后,先不着急使用它,在使用它之前,你还需要了解两个相关的技术,lambda表达式与linq. 作为微软C#语言中重要的语法糖-lambda表达式与LINQ,本质都是一个方法,以la ...

  2. c# in deep 之Lambda表达式于LINQ表达式结合后令人惊叹的简洁(2)

    当Lambda表达式和LINQ一起使用时,我们会发现原本冗长的代码会变得如此简单.比如我们要打印0-10之间的奇数,让其从高到低排列并求其平方根,现在只用一行代码即可完成其集合的生成,直接上代码: v ...

  3. C# Lambda表达式和linq表达式 之 匿名对象查询接收

    很多小伙伴都用过Lambda表达式和linq表达式,用起来也得心应手,但是有的小伙伴 对匿名对象的查询与接收比较迷茫,(没有定义相应的实体),怎么在where()里面进行 条件筛选呢?常规用法我就不说 ...

  4. C#从委托、lambda表达式到linq总结

    前言 本文总结学习C#必须知道的基础知识,委托.监视者模式.常用lambda表达式.linq查询,自定义扩展方法,他们之间有什么关系呢?匿名委托是如何演变成lambda表达式,lambda再如何导出l ...

  5. .net学习之新语法学习(匿名类和匿名方法,扩展方法,系统内置委托,Lambda表达式和linq等)

    1.自动属性 Auto-Implemented Properties 2.隐式类型 var  var变量不能作为全局变量使用,因为不能在编译时确定类型 3.参数默认值 和 命名参数 4.对象初始化器 ...

  6. C#高级知识点概要(3) - 特性、自动属性、对象集合初始化器、扩展方法、Lambda表达式和Linq查询

    1.特性(Attributes) 特性(Attributes),MSDN的定义是:公共语言运行时允许你添加类似关键字的描述声明,叫做attributes, 它对程序中的元素进行标注,如类型.字段.方法 ...

  7. .net Lambda表达式与Linq (LINQ TO object)

    Lambda表达式,是用来写匿名方法的. 在委托用得比较多,因为委托是传递方法的.   定义几个委托: public delegate void DoNoThing();//无参无返回值   publ ...

  8. C# 基础知识系列- 6 Lambda表达式和Linq简单介绍

    前言 C#的lambda和Linq可以说是一大亮点,C#的Lambda无处不在,Linq在数据查询上也有着举足轻重的地位. 那么什么是Linq呢,Linq是 Language Intergrated ...

  9. LINQ查询表达式详解(1)——基本语法、使用扩展方法和Lambda表达式简化LINQ查询

    简介 使用线程的主要原因:应用程序中一些操作需要消耗一定的时间,比如对文件.数据库.网络的访问等等,而我们不希望用户一直等待到操作结束,而是在此同时可以进行一些其他的操作.  这就可以使用线程来实现. ...

随机推荐

  1. java集合框架(一):HashMap

    有大半年没有写博客了,虽然一直有在看书学习,但现在回过来看读书基本都是一种知识“输入”,很多时候是水过无痕.而知识的“输出”会逼着自己去找出没有掌握或者了解不深刻的东西,你要把一个知识点表达出来,自己 ...

  2. python数据类型(集合)

    一.集合概念 集合是一个数学概念:由一个或多个确定的元素所构成的整体叫做集合. 集合中的元素三个特征: 确定性(元素必须可hash) 互异性(去重)——将一个列表变为集合,就自动去重了 无序性(集合中 ...

  3. JavaScirpt(JS)——BOM浏览器对象模型

    一.BOM概念 BOM(Browser Object Model)即浏览器对象模型.可以对浏览器窗口进行访问和操作.使用 BOM,开发者可以移动窗口.改变状态栏中的文本以及执行其他与页面内容不直接相关 ...

  4. SharePoint Server 2010的移动设备配置方案

    随着微软全新一代办公系统Office 2010 的推出,其所支持的移动方案也日渐受到人们的关注,而这些移动功能则是依赖于 SharePoint 2010 的移动性支持.下面就将大家介绍如何设置 Sha ...

  5. 【Spring实战】—— 2 构造注入

    本文讲解了构造注入以及spring的基本使用方式,通过一个杂技演员的例子,讲述了依赖注入属性或者对象的使用方法. 如果想要使用spring来实现依赖注入,需要几个重要的步骤: 1 定义主要的类和需要分 ...

  6. springMVC通过ajax传参到后台

    JSON对象和JSON字符串 在SpringMVC环境中,@RequestBody接收的是一个Json对象的字符串,而不是一个Json对象.然而在ajax请求往往传的都是Json对象,用 JSON.s ...

  7. 源码安装mysql5.6.37

    MYSQL 源码安装: 修改参数文件:vi /etc/security/limits.confmysql soft nproc 2047mysql hard nproc 16384mysql soft ...

  8. python27 文件读写

    fileobject = open(文件的绝对路径或相对路径,读写模式,其他可选参数) '''r-读 文件不存在报错FileNotFoundError''' try: f = open('file0. ...

  9. IOS UIDevice距离传感器(打开 关闭)

    ●  什么是传感器 ●  传感器是一种感应\检测装置, 目前已经广泛应用于智能手机上 ●  iPhone5中内置的传感器有 ●  运动传感器\加速度传感器\加速计(Motion/Acceleromet ...

  10. Ubuntu 配置java环境变量

    1.使用如下命令,打开/etc/profile: $sudo vi /etc/profile 2.进入编辑模式,在末尾添加: #developer enviroment, add by myself ...