整理一下Entity Framework的查询

2012-08-30 13:41:59

标签:Entity Framework

原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://boytnt.blog.51cto.com/966121/977382

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

1、简单查询:

SQL:


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

EF:


  1. //Func形式

  2. var clients = ctx.Clients.Where(c => c.Type == 1 && c.Deleted == 0) 
  3. .OrderBy(c => c.ID) 
  4. .ToList(); 
  5. //Linq形式

  6. var clients = from c in ctx.Clients 
  7. where c.Type == 1 && c.Deleted==0 
  8. orderby c.ID 
  9. select c;


2、查询部分字段:

SQL:


  1. SELECT ID,Name FROM [Clients] WHERE Status=1

EF:


  1. //Func形式

  2. var clients = ctx.Clients.Where(c => c.Status == 1) 
  3. .Select(c => new { c.ID, Name = c.ComputerName }) 
  4. .ToList(); 
  5. //Linq形式

  6. var clients = from c in ctx.Clients 
  7. where c.Status == 1 
  8. select new { c.ID, Name = c.ComputerName };

3、查询单一记录:

SQL:


  1. SELECT * FROM [Clients] WHERE ID=100

EF:


  1. //Func形式

  2. var client = ctx.Clients.FirstOrDefault(c => c.ID == 100); 
  3. //Linq形式

  4. var client = (from c in ctx.Clients 
  5. where c.ID = 100 
  6. select c).FirstOrDefault();


4、LEFT JOIN 连接查询

SQL:


  1. SELECT c.ID,c.ComputerName,g.Name GroupName  
  2. FROM [Clients] c  
  3. LEFT JOIN [Groups] g 
  4. ON c.GroupID = g.ID 
  5. WHERE c.Status=1

EF:


  1. //Func形式

  2. var clients = ctx.Clients.Where(c => c.Status == 1) 
  3. .Select(c => new

  4. c.ID, 
  5. c.ComputerName, 
  6. GroupName = ctx.Groups.FirstOrDefault(g => g.ID == c.GroupID).Name 
  7. }) 
  8. .ToList(); 
  9. //Linq形式

  10. var clients = from c in ctx.Clients 
  11. where c.Status == 1 
  12. select new

  13. c.ID, 
  14. c.ComputerName, 
  15. GroupName = (from g in ctx.Groups 
  16. where g.ID == c.GroupID 
  17. select g.Name).FirstOrDefault() 
  18. };

5、INNER JOIN 连接查询:

SQL:


  1. SELECT c.ID,c.ComputerName,g.Name GroupName  
  2. FROM [Clients] c 
  3. INNER JOIN [Groups] g 
  4. ON c.GroupID = g.ID 
  5. WHERE c.Status=1 
  6. ORDER BY g.Name

EF:


  1. //Func形式

  2. var clients = ctx.Clients.Where(c => c.Status == 1) 
  3. .Join(ctx.Group, c => c.GroupID, g => g.ID, (c,g) =>  
  4. c.ID, 
  5. c.ComputerName, 
  6. GroupName = g.Name 
  7. }) 
  8. .OrderBy(item => item.GroupName) 
  9. .ToList(); 
  10. //Linq形式1

  11. var clients = from c in ctx.Clients 
  12. from g in ctx.Groups 
  13. where c.GroupID == g.ID 
  14. orderby g.Name 
  15. select new

  16. c.ID, 
  17. c.ComputerName, 
  18. GroupName = g.Name 
  19. }; 
  20. //Linq形式2

  21. var clients = from c in ctx.Clients 
  22. where c.Status == 1 
  23. join g in ctx.Group 
  24. on c.GroupID equals g.ID into result 
  25. from r in result 
  26. order by r.Name 
  27. select new

  28. c.ID, 
  29. c.ComputerName, 
  30. GroupName = r.Name 
  31. };


6、分页

SQL:


  1. -- 方案1

  2. SELECT TOP 10 * FROM [Clients] WHERE Status=1 
  3. AND ID NOT IN

  4. SELECT TOP 20 ID FROM [Clients] WHERE Status=1 
  5. ORDER BY ComputerName 
  6. ORDER BY ComputerName 
  7. --方案2

  8. SELECT * FROM
  9. SELECT *, ROW_NUMBER() OVER(ORDER BY ComputerName) AS RowNo 
  10. FROM [Clients] 
  11. WHERE Status=1 
  12. )t 
  13. WHERE RowNo >= 20 AND RowNo < 30

EF:


  1. //Func形式

  2. var clients = ctx.Clients.Where(c => c.Status=1) 
  3. .OrderBy(c => c.ComputerName) 
  4. .Skip(20) 
  5. .Take(10) 
  6. .ToList(); 
  7. //Linq形式

  8. var clients = (from c in ctx.Clients 
  9. orderby c.ComputerName 
  10. select c).Skip(20).Take(10);

7、分组统计:

SQL:


  1. SELECT Status,COUNT(*) AS Cnt FROM [Clients]  
  2. GROUP BY Status 
  3. ORDER BY COUNT(*) DESC

EF:


  1. //Func形式

  2. var result = ctx.Clients.GroupBy(c => c.Status) 
  3. .Select(s => new

  4. Status = s.Key, 
  5. Cnt = s.Count() 
  6. }) 
  7. .OrderByDescending(r => r.Cnt); 
  8. //Linq形式

  9. var result = from c in ctx.Clients 
  10. group c by c.Status into r 
  11. orderby r.Count() descending 
  12. select new

  13. Status = r.Key, 
  14. Cnt = r.Count() 
  15. };

未完待续……

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

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

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

  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. 【收藏】Android屏幕适配全攻略(最权威的Google官方适配指导)

    来源:http://blog.csdn.net/zhaokaiqiang1992 更多:Android AutoLayout全新的适配方式, 堪称适配终结者 Android的屏幕适配一直以来都在折磨着 ...

  2. 【USACO 2.2】Subset Sums (DP)

    N (1 <= N <= 39),问有多少种把1到N划分为两个集合的方法使得两个集合的和相等. 如果总和为奇数,那么就是0种划分方案.否则用dp做. dp[i][j]表示前 i 个数划分到 ...

  3. 【Codeforces 723C】Polycarp at the Radio 贪心

    n个数,用最少的次数来改变数字,使得1到m出现的次数的最小值最大.输出最小值和改变次数以及改变后的数组. 最小值最大一定是n/m,然后把可以改变的位置上的数变为需要的数. http://codefor ...

  4. yii自动登录

    在yii,登录页面选择记住密码,下次就会自动登陆 前些天,自己增加了一个web应用,但是发现虽然选择记住密码,没选退出,关闭浏览器,重新进入还会跳转到登陆页面 自动登录是利用cookie实现的 配置U ...

  5. 关于如何获取第三方app包内图片资源的方法

    如果想获取其他app的图片资源,简直是易如反掌,如下提供两种方法,其实本质上是一种方法. 方法一: First:登陆itunes,在itunes里的appstore栏找到已购项目,里面有你的账号所下载 ...

  6. 【BZOJ-1576】安全路径Travel Dijkstra + 并查集

    1576: [Usaco2009 Jan]安全路经Travel Time Limit: 10 Sec  Memory Limit: 64 MBSubmit: 1044  Solved: 363[Sub ...

  7. java integer对象判断两个数字是否相等

    java integer对象判断两个数字是否相等,不一定对 问题发生的背景:javaweb的项目,起先,因为在java中实体类中的int类型在对象初始化之后会给int类型的数据默认赋值为0,这样在很多 ...

  8. angularjs 手动加载

    利用ng-app可以完成自动加载,如果不利用ng-app.那么使用bootstrarp实现手动加载模块 <html> <head> <script src="a ...

  9. 在打开vs解决方案时,怎样让所以打开的项目自动折叠

    使用VS 2010中的扩展性,搜PowerCommands,PowerCommands扩展在Visual Studio 2010中添加了数十个有用的的命令, Collapse Projects(折叠项 ...

  10. shell实现的守护进程

    代码本来是别人那里拿来的,自己又改了下,给busybox用. #! /bin/sh PRO_PATH=/opt/myapp PROGRAM=packet_analyzer while true ; d ...