Entity Framework是个好东西,虽然没有Hibernate功能强大,但使用更简便。今天整理一下常见SQL如何用EF来表达,Func形式和Linq形式都会列出来(本人更喜欢Func形式)。

1、简单查询:

SQL:

SELECT * FROM [Clients] WHERE Type=1 AND Deleted=0 ORDER BY ID

EF:

  • //Func形式
  • var clients = ctx.Clients.Where(c => c.Type == 1 && c.Deleted == 0)
  •             .OrderBy(c => c.ID)
  •             .ToList();
  •  
  • //Linq形式
  • var clients = from c in ctx.Clients
  •               where c.Type == 1 && c.Deleted==0
  •               orderby c.ID
  •               select c;


  • 2、查询部分字段:

    SQL:

  • SELECT ID,Name FROM [Clients] WHERE Status=1
  • EF:

  • //Func形式
  • var clients = ctx.Clients.Where(c => c.Status == 1)
  •             .Select(c => new { c.ID, Name = c.ComputerName })
  •             .ToList();
  •  
  • //Linq形式
  • var clients = from c in ctx.Clients
  •               where c.Status == 1
  •               select new { c.ID, Name = c.ComputerName };
  • 3、查询单一记录:

    SQL:

  • SELECT * FROM [Clients] WHERE ID=100
  • EF:

  • //Func形式
  • var client = ctx.Clients.FirstOrDefault(c => c.ID == 100);
  •  
  • //Linq形式
  • var client = (from c in ctx.Clients
  •             where c.ID = 100
  •             select c).FirstOrDefault();


  • 4、LEFT JOIN 连接查询

    SQL:

  • SELECT c.ID,c.ComputerName,g.Name GroupName 
  • FROM [Clients] c 
  • LEFT JOIN [Groups] g
  • ON c.GroupID = g.ID
  • WHERE c.Status=1
  • EF:

  • //Func形式
  • var clients = ctx.Clients.Where(c => c.Status == 1)
  •             .Select(c => new 
  •             {
  •                 c.ID,
  •                 c.ComputerName,
  •                 GroupName = ctx.Groups.FirstOrDefault(g => g.ID == c.GroupID).Name
  •             })
  •             .ToList();
  •  
  • //Linq形式
  • var clients = from c in ctx.Clients
  •             where c.Status == 1
  •             select new
  •             {
  •                 c.ID,
  •                 c.ComputerName,
  •                 GroupName = (from g in ctx.Groups
  •                             where g.ID == c.GroupID
  •                             select g.Name).FirstOrDefault()
  •             };
  • 5、INNER JOIN 连接查询:

    SQL:

  • SELECT c.ID,c.ComputerName,g.Name GroupName 
  • FROM [Clients] c
  • INNER JOIN [Groups] g
  • ON c.GroupID = g.ID
  • WHERE c.Status=1
  • ORDER BY g.Name
  • EF:

  • //Func形式
  • var clients = ctx.Clients.Where(c => c.Status == 1)
  •             .Join(ctx.Group, c => c.GroupID, g => g.ID, (c,g) => 
  •             {
  •                 c.ID,
  •                 c.ComputerName,
  •                 GroupName = g.Name
  •             })
  •             .OrderBy(item => item.GroupName)
  •             .ToList();
  •  
  •  
  • //Linq形式1
  • var clients = from c in ctx.Clients
  •             from g in ctx.Groups
  •             where c.GroupID == g.ID
  •             orderby g.Name
  •             select new
  •             {
  •                 c.ID,
  •                 c.ComputerName,
  •                 GroupName = g.Name
  •             };
  •  
  • //Linq形式2
  • var clients = from c in ctx.Clients
  •             where c.Status == 1
  •             join g in ctx.Group
  •             on c.GroupID equals g.ID into result
  •             from r in result
  •             order by r.Name
  •             select new
  •             {
  •                 c.ID,
  •                 c.ComputerName,
  •                 GroupName = r.Name
  •             };


  • 6、分页

    SQL:

  • -- 方案1
  • SELECT TOP 10 * FROM [Clients] WHERE Status=1
  • AND ID NOT IN 
  • (
  •     SELECT TOP 20 ID FROM [Clients] WHERE Status=1
  •     ORDER BY ComputerName
  • )
  • ORDER BY ComputerName
  •  
  • --方案2
  • SELECT * FROM
  • (
  •     SELECT *, ROW_NUMBER() OVER(ORDER BY ComputerName) AS RowNo
  •     FROM [Clients]
  •     WHERE Status=1
  • )t
  • WHERE RowNo >= 20 AND RowNo < 30
  • EF:

  • //Func形式
  • var clients = ctx.Clients.Where(c => c.Status=1)
  •             .OrderBy(c => c.ComputerName)
  •             .Skip(20)
  •             .Take(10)
  •             .ToList();
  •  
  • //Linq形式
  • var clients = (from c in ctx.Clients
  •             orderby c.ComputerName
  •             select c).Skip(20).Take(10);
  • 7、分组统计:

    SQL:

  • SELECT Status,COUNT(*) AS Cnt FROM [Clients] 
  • GROUP BY Status
  • ORDER BY COUNT(*) DESC
  • EF:

  • //Func形式
  • var result = ctx.Clients.GroupBy(c => c.Status)
  •             .Select(s => new
  •             {
  •                 Status = s.Key,
  •                 Cnt = s.Count()
  •             })
  •             .OrderByDescending(r => r.Cnt);
  •  
  • //Linq形式
  • var result = from c in ctx.Clients
  •             group c by c.Status into r
  •             orderby r.Count() descending
  •             select new
  •             {
  •                 Status = r.Key,
  •                 Cnt = r.Count()
  •             };
  • 未完待续……

    转:整理一下Entity Framework的查询的更多相关文章

    1. 整理一下Entity Framework的查询

      整理一下Entity Framework的查询 2012-08-30 13:41:59 标签:Entity Framework 原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信 ...

    2. 整理一下Entity Framework的查询 [转]

      Entity Framework是个好东西,虽然没有Hibernate功能强大,但使用更简便.今天整理一下常见SQL如何用EF来表达,Func形式和Linq形式都会列出来(本人更喜欢Func形式). ...

    3. Entity Framework的查询

      Entity Framework是个好东西,虽然没有Hibernate功能强大,但使用更简便.今天整理一下常见SQL如何用EF来表达,Func形式和Linq形式都会列出来(本人更喜欢Func形式). ...

    4. Entity Framework 简单查询

      前言 首先来简单的复习一下如何使用Code First. 第一步还是先建立一个控制台的应用程序,然后通过Nuget添加Entity Framework.那么同时会给packages.config和Ap ...

    5. Entity Framework异步查询和保存

      EF6开始提供了通过async和await关键字实现异步查询和保存的支持(.net 4.5及更高版本).虽然不是所有的操作都能从异步中获益,但是耗时的操作.网络或IO密集型任务中,使用异步可以提升客户 ...

    6. Entity Framework关联查询以及数据加载(延迟加载,预加载)

      数据加载分为延迟加载和预加载 EF的关联实体加载有三种方式:Lazy Loading,Eager Loading,Explicit Loading,其中Lazy Loading和Explicit Lo ...

    7. Entity Framework (二) 查询

      待完善-------------------------------------- ----------- base 关键字用于从派生类中访问基类的成员: 调用基类上已被其他方法重写的方法. 指定创建 ...

    8. Entity Framework: 视图查询时重复返回第一行值, duplicate frst rows in resultset from a view

      http://blog.csdn.net/riverlau/article/details/7476449 1. 使用rownumber给view加上一个标示列 SELECT ROW_NUMBER() ...

    9. C# Entity Framework查询小技巧 NoTracking

      在使用Entity Framework做查询的时候,如果只需要显示,而不用保存实体,那么可以用AsNoTracking()来获取数据. 这样可以提高查询的性能. 代码如下: var context = ...

    随机推荐

    1. [C++]类的继承与派生

      继承性是面向对象程序设计的第二大特性,它允许在既有类的基础上创建新类,新类可以继承既有类的数据成员和成员函数,可以添加自己特有的数据成员和成员函数,还可以对既有类中的成员函数重新定义.利用类的继承和派 ...

    2. MetInfo安装

      安装MetInfo企业网站管理系统需要经历三个步骤:安装准备.上传文件.安装系统. 第一步:安装前的准备 环境要求:需要支持PHP并提供Mysql数据库的空间(虚拟主机),详细要求: 下载MetInf ...

    3. 创建MySQL存储过程示例

      创建MySQL存储过程是学习MySQL数据库必须要掌握的知识,下文对创建MySQL存储过程作了详细的介绍,供您参考学习. AD:2013大数据全球技术峰会课程PPT下载 下文将教您如何创建MySQL存 ...

    4. 传说中的WCF(6):数据协定(b)

      我们继续,上一回我们了解了数据协定的一部分内容,今天我们接着来做实验.好的,实验之前先说一句:实验有风险,写代码须谨慎. 实验开始!现在,我们定义两个带数据协定的类——Student和AddrInfo ...

    5. 李洪强iOS开发之添加手势

      李洪强iOS开发之添加手势 02 - 添加手势

    6. Android SlidingMenu侧滑菜单使用

      把下载的侧滑菜单压缩包打开,会有一个library文件夹,在eclipse中import existing android code into workspace,导入library文件夹,并且选择作 ...

    7. Android核心分析之二十Android应用程序框架之无边界设计意图

      Android应用程序框架1 无边界设计理念 Android的应用框架的外特性空间的描述在SDK文档(http://androidappdocs.appspot.com/guide/topics/fu ...

    8. 做一款仿映客的直播App

      投稿文章,作者:JIAAIR(GitHub) 一.直播现状简介 1.技术实现层面 技术相对都比较成熟,设备也都支持硬编码.iOS还提供现成的Video ToolBox框架,可以对摄像头和流媒体数据结构 ...

    9. ios--集成支付宝钱包支付iOS SDK的方法与经验

      文/胖花花(简书作者)原文链接:http://www.jianshu.com/p/fe56e122663e著作权归作者所有,转载请联系作者获得授权,并标注“简书作者”. 没想到,支付宝的SDK是我目前 ...

    10. 也谈SWD接口协议分析

      这几日看到坛里有几个关于SWD协议相关的文章,自己也尝试了下,有点体会,也有些疑惑,写出来与大家分享和交流下.    以下我的模拟SWD接口的板子简称为Host,目标MCU(即我要连接的板子)简称为T ...