zoukankan      html  css  js  c++  java
  • lambda表达式查询经验:IN 和groupby的使用

    lambda In的用法:

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

    如下代码:

    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 表达式查询也能实现

    //单个分组GROUP BY
    
    var rels= rel.GroupBy(a => a.PlatformName).Select(s=>new MarketInfoInvalidRatioExtend 
    { 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
    { g.PlatformName, g.BusinessName, g.DepartmentName, g.ResourceName }).Select(s=>new MarketInfoInvalidRatioExtend
    { PlatformName=s.Key.PlatformName, BusinessName=s.Key.BusinessName, DepartmentName=s.Key.DepartmentName, ResourceName=s.Key.ResourceName,
    AssignNum =s.Sum(w=>w.AssignNum), EmptyNum = s.Sum(w => w.EmptyNum), BlacklistNum=s.Sum(w=>w.BlacklistNum), ErrorNum= s.Sum(w => w.ErrorNum),
    InvalidNum=s.Sum(w=>w.InvalidNum) });

      

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

  • 相关阅读:
    [CF590C] Three States
    [CF767B] The Queue
    [CF1296F] Berland Beauty
    [CF3D] Least Cost Bracket Sequence
    YUV420 转 RGB 测试
    [POI2012] TOU-Tour de Byteotia
    [CF576C] Points on Plane
    [CF191C] Fools and Roads
    [CF1485C] Floor and Mod
    [CF1399D] Binary String To Subsequences
  • 原文地址:https://www.cnblogs.com/xbhp/p/6431537.html
Copyright © 2011-2022 走看看