VB.net 2010 视频教程 VB.net 2010 视频教程 python基础视频教程
SQL Server 2008 视频教程 c#入门经典教程 Visual Basic从门到精通视频教程
当前位置:
首页 > Python基础教程 >
  • C#教程之LAMBDA表达式查询经验:IN 和GROUPBY的使用

lambda In的用法:

lambda表达式查询没有IN这个方法,可以变通一下,in查询的数组是否包含在映射对象里面的集合里:

如下代码:

 

1
2
3
var departmentIDs = input.DepartmentIDs.Split(',').Select(s => int.Parse(s)).ToList();//这是从前端传进来的字符串数组,需要转换成int
 
db.whereLambda.Add(d => departmentIDs.Contains(d.DepartmentID));//whereLambda是where条件里面的lamdba表达式,db是上下文数据。这句话就是实体集合是否包含departmentIDs 。

 

SQL:select * from db where DepartmentID in(departmentIDs)

 

lambda groupby的用法

计算各种统计在数据库用group by 

GROUP BY 语句用于结合合计函数,根据一个或多个列对结果集进行分组

然后计算,在数据库计算统计用的非常多

我们这里用lambda 表达式查询也能实现

 

1
2
3
4
5
6
7
8
9
//单个分组GROUP BY
 
var rels= rel.GroupBy(a => a.PlatformName).Select(s=>new MarketInfoInvalidRatioExtend <br>{ BusinessName = s.Key,AssignNum=s.Sum(c=>c.AssignNum),InvalidNum=s.Sum(I=>I.InvalidNum)} ).ToList();
 
 
 
//多个分组GROUP BY
 
var rel = db.FindList(10000, db.whereLambda, b => b.MKBTID, true).GroupBy(g => new <br>{ g.PlatformName, g.BusinessName, g.DepartmentName, g.ResourceName }).Select(s=>new MarketInfoInvalidRatioExtend <br>{ PlatformName=s.Key.PlatformName, BusinessName=s.Key.BusinessName, DepartmentName=s.Key.DepartmentName, ResourceName=s.Key.ResourceName,<br> AssignNum =s.Sum(w=>w.AssignNum), EmptyNum = s.Sum(w => w.EmptyNum), BlacklistNum=s.Sum(w=>w.BlacklistNum), ErrorNum= s.Sum(w => w.ErrorNum),<br> InvalidNum=s.Sum(w=>w.InvalidNum) });

  

注意的是Select NEW 一个新实体的本身不能与查询的集合实体相同,否则会报错“在 LINQ to Entities 查询中无法构造实体或复杂类型""”。


相关教程