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 == && c.Deleted == )
.OrderBy(c => c.ID)
.ToList();
//Linq形式
var clients = from c in ctx.Clients
where c.Type == && c.Deleted==
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 == )

            .Select(c => new { c.ID, Name = c.ComputerName })

            .ToList();

//Linq形式

var clients = from c in ctx.Clients

              where c.Status == 

              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 == );
//Linq形式
var client = (from c in ctx.Clients
where c.ID =
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 == )
.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 == 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:

  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. {
  5. c.ID,
  6. c.ComputerName,
  7. GroupName = g.Name
  8. })
  9. .OrderBy(item => item.GroupName)
  10. .ToList();
  11. //Linq形式1
  12. var clients = from c in ctx.Clients
  13. from g in ctx.Groups
  14. where c.GroupID == g.ID
  15. orderby g.Name
  16. select new
  17. {
  18. c.ID,
  19. c.ComputerName,
  20. GroupName = g.Name
  21. };
  22. //Linq形式2
  23. var clients = from c in ctx.Clients
  24. where c.Status == 1
  25. join g in ctx.Group
  26. on c.GroupID equals g.ID into result
  27. from r in result
  28. order by r.Name
  29. select new
  30. {
  31. c.ID,
  32. c.ComputerName,
  33. GroupName = r.Name
  34. };


6、分页

SQL:

  1. -- 方案1
  2. SELECT TOP 10 * FROM [Clients] WHERE Status=1
  3. AND ID NOT IN
  4. (
  5. SELECT TOP 20 ID FROM [Clients] WHERE Status=1
  6. ORDER BY ComputerName
  7. )
  8. ORDER BY ComputerName
  9. --方案2
  10. SELECT * FROM
  11. (
  12. SELECT *, ROW_NUMBER() OVER(ORDER BY ComputerName) AS RowNo
  13. FROM [Clients]
  14. WHERE Status=1
  15. )t
  16. 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. {
  5. Status = s.Key,
  6. Cnt = s.Count()
  7. })
  8. .OrderByDescending(r => r.Cnt);
  9. //Linq形式
  10. var result = from c in ctx.Clients
  11. group c by c.Status into r
  12. orderby r.Count() descending
  13. select new
  14. {
  15. Status = r.Key,
  16. Cnt = r.Count()
  17. };

未完待续……

Entity Framework的查询的更多相关文章

  1. 整理一下Entity Framework的查询

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

  2. Entity Framework 简单查询

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

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

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

  4. 转:整理一下Entity Framework的查询

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

  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. iPhone6/6Plus下app状态栏内容放大问题处理

    分为兼容模式和高分辨率模式. 兼容模式 当你的 app 没有提供 3x 的 LaunchImage 时,系统默认进入兼容模式,大屏幕一切按照 320 宽度渲染,屏幕宽度返回 320:然后等比例拉伸到大 ...

  2. MAC终端:如何调整字体大小和终端样式

    1.字体 进入终端后comman键和+键的组合可以增大显示 2.样式  

  3. 自定义view布局过程详解

    布局过程,就是程序在运行时利用布局文件的代码来计算出实际尺寸的过程. 布局分为两个阶段:测量阶段和布局阶段. 测量阶段:从上到下递归地调用每个 View 或者 ViewGroup 的 measure( ...

  4. React事件处理函数传参问题

    React事件处理函数参数 HTML标签与React 组件是不同的,事件对象e是HTML标签元素的,组件没有的.

  5. Android之高仿手机QQ聊天

    源代码下载 转载请注明出处,谢谢! 最终版已上传.优化下拉刷新.增加来消息声音提示.主界面改成ViewPager,实现左右滑动.新增群组.最近会话显示条数,开始上班了,不再修改了.谢谢! 国庆这几天, ...

  6. WPF去除边框的方法

    原文:WPF去除边框的方法 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/yangsen600/article/details/81978125 W ...

  7. 衡量镜头解像能力性能的指标-MTF曲线

    MTF(Modulation Transfer Function,模量传递函数),是目前分析镜头解像能力的方法,可以用来评判镜头还原物体对比度的能力.说到MTF,不得不先提一下衡量镜头性能的两在重要指 ...

  8. 将您的Cordova应用程序打包

    参考 https://github.com/MicrosoftDocs/cordova-docs/blob/master/articles/tutorial-package-publish/tutor ...

  9. python 简单的Socket编程

    python 编写server的步骤: 1第一步是创建socket对象.调用socket构造函数.如: socket = socket.socket(family, type ) family参数代表 ...

  10. 在.net core的web项目中使用kindeditor

    本项目是一个.net core的mvc项目 1.下载kindeditor 4.1.11 解压后将文件夹置于 wwwroot目录下,如图: 2.在HomeController的Index控制器对应的in ...