从网上收藏的复杂Linq语句写法

1、case when:

原型:

sql原型:

SELECT ProductID, Name, Color,

CASE

WHEN Color = 'Red' THEN StandardCost

WHEN Color = 'Black' THEN StandardCost + 10

ELSE ListPrice

END Price

FROM SalesLT.Product

Linq代码:

Products.Select(P => new

{

ID = P.ProductID,

Name = P.Name,

Color = P.Color,

Price = (P.Color == "Red" ? P.StandardCost : (P.Color == "Black" ? P.StandardCost + 10 : P.ListPrice))

});

2、where中使用case when

linq代码:

Products

.Where(P => (P.Color == "Red" ? (P.StandardCost > 100) : (P.Color == "Black" ? P.ListPrice > 100 : P.ListPrice == P.StandardCost)))

.Select(P => new

{

ID = P.ProductID,

Name = P.Name,

Color = P.Color,

StandardCost = P.StandardCost,

ListPrice = P.ListPrice

});

sql原型:

SELECT ProductID, Name, Color, StandardCost, ListPrice

FROM SalesLT.Product

WHERE (

(CASE

WHEN Color = 'Red' THEN

(CASE

WHEN StandardCost > 100 THEN 1

WHEN NOT (StandardCost > 100) THEN 0

ELSE NULL

END)

WHEN Color = 'Black' THEN

(CASE

WHEN ListPrice > 100 THEN 1

WHEN NOT (ListPrice > 100) THEN 0

ELSE NULL

END)

ELSE

(CASE

WHEN ListPrice = StandardCost THEN 1

WHEN NOT (ListPrice = StandardCost) THEN 0

ELSE NULL

END)

END)) = 1

3、group by中使用case when

linq代码:

Products.GroupBy(P => P.StandardCost > 1000? P.Color : P.SellStartDate.ToString())

sql原型:

-- Region Parameters

DECLARE @p0 Decimal(8,4) = 1000

-- EndRegion

SELECT [t1].[value] AS [Key]

FROM (

SELECT

(CASE

WHEN [t0].[StandardCost] > @p0 THEN CONVERT(NVarChar(MAX),[t0].[Color])

ELSE CONVERT(NVarChar(MAX),[t0].[SellStartDate])

END) AS [value]

FROM [SalesLT].[Product] AS [t0]

) AS [t1]

GROUP BY [t1].[value]

4、单表的查询

var query = from tc in db.tbClass

where tc.ClassID == "1"

//查询表tbClass

select new {

ClassID=tc.ClassID,

ClassName=tc.ClassName

5、多表内连接查询

var query = from s in db.tbStudents

join c in db.tbClass on s.ClassID equals c.ClassID

where s.ClassID == 3

select new

{

ClassID = s.ClassID,

ClassName = c.ClassName,

Student = new

{

Name = s.Name,

StudentID = s.StudentID

}

};

6、外连接

var query = from s in db.tbStudents

join c in db.tbClass on s.ClassID equals c.ClassID into tbC

from tbCw in tbC.DefaultIfEmpty()

where s.ClassID == 3

select new

{

ClassID = s.ClassID,

ClassName = tbCw.ClassName,

Student = new

{

Name = s.Name,

StudentID = s.StudentID

}

};

7、多表关联

listUser = (from u in dbcontext.t_user

join g in dbcontext.t_grade on u.gradeID equals g.gradeID

join s in dbcontext.t_states on u.state equals s.statesID

join c in dbcontext.t_character on u.levelID equals c.levelID

select new userModel()

{

userID=u.userID,

userName=u.userName,

userGrade=g.userGrade,

userStates=s.userSates,

userLevel=c.userLevel,

totalMcoin=u.totalMcoin

}).ToList();

————————————————
版权声明:本文为CSDN博主「xjzdr」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/xjzdr/article/details/81179290

复杂Linq语句写法的更多相关文章

  1. C#DataTable 使用GroupBy方法的lamda 表达式和Linq语句写法

    https://www.cnblogs.com/johnblogs/p/6006867.html DataTable ds = new DataTable(); //1.lamda 表达式写法(推荐) ...

  2. LINQ语句中的.AsEnumerable() 和 .AsQueryable()的区别

    LINQ语句中的.AsEnumerable() 和 .AsQueryable()的区别 在写LINQ语句的时候,往往会看到.AsEnumerable() 和 .AsQueryable() .例如: s ...

  3. 动态拼接linq 使用Expression构造动态linq语句

    最近在做动态构造linq语句,从网上找了很多,大多数,都是基于一张表中的某一个字段,这样的结果,从网上可以搜到很多.但如果有外键表,需要动态构造外键表中的字段,那么问题来了,学挖掘机哪家强?哦,不是, ...

  4. [转]在Entity Framework中使用LINQ语句分页

    本文转自:http://diaosbook.com/Post/2012/9/21/linq-paging-in-entity-framework 我们知道,内存分页效率很低.并且,如果是WebForm ...

  5. Linq语句基础

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...

  6. [转]LINQ语句之Select/Distinct和Count/Sum/Min/Max/Avg

    在讲述了LINQ,顺便说了一下Where操作,这篇开始我们继续说LINQ语句,目的让大家从语句的角度了解LINQ,LINQ包括LINQ to Objects.LINQ to DataSets.LINQ ...

  7. python最简洁的条件判断语句写法

    这篇文章主要介绍了Python返回真假值(True or False)小技巧,本文探讨的是最简洁的条件判断语句写法,本文给出了两种简洁写法,需要的朋友可以参考下 如下一段代码: def isLen(s ...

  8. MVC4数据访问EF查询linq语句的时候报错找不到表名问题

    一天做项目的时候遇到这样的问题,MVC4用EF访问数据查询用linq语句的时候报错找不到表名:报错如下图: 研究了几种情况,最后还是没有找到正真的问题所在,不过可能是和路由解析问题有关,暂时还没有进行 ...

  9. discuz 万能SQL查询调用语句写法

    首先在最底层source\class\table写入底层安全调用文件例如:table_common_friendlink.php 代码: <?php /** * [Discuz!] (C)200 ...

随机推荐

  1. 官网下载 Linux 上需要的 MySQL的步骤

    1.输入MySQL 官网地址  https://dev.mysql.com/  选择 download ->Community->MySQL Community Server 点击 MyS ...

  2. MySQL主键跟外键

    定义主键和外键主要是为了维护关系数据库的完整性,总结一下: 1.主键是能确定一条记录的唯一标识,比如,一条记录包括身份正号,姓名,年龄. 身份证号是唯一能确定你这个人的,其他都可能有重复,所以,身份证 ...

  3. 开放应用模型(OAM):全球首个云原生应用标准定义与架构模型

    Kubernetes 项目作为容器编排领域的事实标准, 成功推动了诸如阿里云 Kubernetes (ACK)等云原生服务的迅速增长.但同时我们也关注到,Kubernetes 的核心 API 资源比如 ...

  4. 牛客多校第三次B——线段树维护线性基交

    写线性基交函数时调试了半天.. #include<bits/stdc++.h> using namespace std; #define ll long long #define maxn ...

  5. NX-二次开发创建圆弧(三点圆弧)UF_CURVE_create_arc_3point

    NX9+VS2012 #include <uf.h> #include <uf_curve.h> UF_initialize(); //起点 ]; ArcStartPoint[ ...

  6. NX二次开发-UFUN获取图纸视图最大边界和视图中心点UF_DRAW_ask_view_borders

    NX9+VS2012 //获得视图的最大边界 ]; UF_DRAW_ask_view_borders(view_tag[j], view_borders); //获得视图原点 ]; ViewOrigi ...

  7. js的线程和同步异步以及console.log机制

    项目上线了,闲下来就写写东西吧.积累了好多东西都没有做笔记~挑几个印象深刻的记录一下吧. js的同步异步以及单线程问题: 都知道单线程是js的一大特性.但是通常io(ajax获取服务器数据).用户/浏 ...

  8. JDK 安装步骤

    1.JAVA_HOME  =  JDK安装路径 2.  Path  =  %JAVA_HOME%\bin; 3.  CLASSPATH   =  .;%JAVA_HOME%\lib\dt.jar;%J ...

  9. beaglebone black 与电脑互传文件(夹)

    1. PSCP方法 PSCP,是putty的一个组件. 1.1 下载PSCP 先给连接http://www.chiark.greenend.org.uk/~sgtatham/putty/downloa ...

  10. JavaScript学习总结(七)——ECMAScript6(ES6)

    一.ECMAScript概要 ECMAScript是一种由Ecma国际(前身为欧洲计算机制造商协会,英文名称是European Computer Manufacturers Association)通 ...