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. Delphi中@,^,#,$特殊符号意义

      概述:   ^: 指针   @: 取址   #: 十进制符   $: 十六进制符   @:取址运算符; var   int:integer;   p:^integer; begin   new(P); ...

    2. (转)8 reviews about de novo genome assembly

      转自:http://dskernel.blogspot.com/2012/04/8-reviews-about-de-novo-genome-assembly.html 8 reviews about ...

    3. POJ 1650

      #include <iostream> #include <cmath> //wo de 编译器里的这个abs的功能不能用啊! using namespace std; int ...

    4. Java加密技术

      相关链接: Java加密技术(一)——BASE64与单向加密算法MD5&SHA&MAC Java加密技术(二)——对称加密DES&AES Java加密技术(三)——PBE算法  ...

    5. lintcode:交换链表当中两个节点

      题目 给你一个链表以及两个权值v1和v2,交换链表中权值为v1和v2的这两个节点.保证链表中节点权值各不相同,如果没有找到对应节点,那么什么也不用做. 注意事项 你需要交换两个节点而不是改变节点的权值 ...

    6. Dire Wolf ---hdu5115(区间dp)

      题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5115 题意:有一排狼,每只狼有一个伤害A,还有一个伤害B.杀死一只狼的时候,会受到这只狼的伤害A和这只 ...

    7. iOS 证书调试的理解(Personal)

      证书签名 证书:众所周知,我们申请一个Certificate之前,需要先申请一个Certificate Signing Request (CSR) 文件,而这个过程中实际上是生成了一对公钥和私钥,保存 ...

    8. SSIS ->> Event Handler

      Event Handler支持在某个事件触发的时候定义好处理该事件的逻辑,比如错误事件触发是该怎么处理.它跟Control Flow界面相似,就好像执行了另外一个包一样.Event Handler不仅 ...

    9. Oracle在linux下的开机自启动(详细)转

      linux下系统开机oracle自启动(方法一) ---加载为服务自启动.停止一.dbstart   及   dbshut 1. 修改Oracle系统配置文件:/etc/oratab,只有这样,Ora ...

    10. css 射线实现方法

      一个斜的四边形 .top_ad_out::before { content: ''; position: absolute; z-index: -1; width: 336px; height: 25 ...