博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Linq使用Group By经验总结
阅读量:7062 次
发布时间:2019-06-28

本文共 1341 字,大约阅读时间需要 4 分钟。

介绍Linq使用Group By问题的解决方法。

1.计数

var q =  from p in db.Products  group p by p.CategoryID into g  select new {  g.Key,  NumProducts = g.Count()  };

语句描述:Linq使用Group By和Count得到每个CategoryID中产品的数量。

说明:先按CategoryID归类,取出CategoryID值和各个分类产品的数量。

2.带条件计数

var q =  from p in db.Products  group p by p.CategoryID into g  select new {  g.Key,  NumProducts = g.Count(p => p.Discontinued)  };

语句描述:Linq使用Group By和Count得到每个CategoryID中断货产品的数量。

说明:先按CategoryID归类,取出CategoryID值和各个分类产品的断货数量。 Count函数里,使用了Lambda表达式,Lambda表达式中的p,代表这个组里的一个元素或对象,即某一个产品。

3.Where限制

var q =  from p in db.Products  group p by p.CategoryID into g  where g.Count() >= 10  select new {  g.Key,  ProductCount = g.Count()  };

语句描述:根据产品的―ID分组,查询产品数量大于10的ID和产品数量。这个示例在Group By子句后使用Where子句查找所有至少有10种产品的类别。

说明:在翻译成SQL语句时,在最外层嵌套了Where条件。

4.多列(Multiple Columns)

var categories =  from p in db.Products  group p by new  {  p.CategoryID,  p.SupplierID  }  into g  select new  {  g.Key,  g  };

语句描述:Linq使用Group By按CategoryID和SupplierID将产品分组。

说明:既按产品的分类,又按供应商分类。在by后面,new出来一个匿名类。这里,Key其实质是一个类的对象,Key包含两个Property:CategoryID、SupplierID。用g.Key.CategoryID可以遍历CategoryID的值。

5.表达式(Expression)

var categories =  from p in db.Products  group p by new { Criterion = p.UnitPrice > 10 } into g  select g;

语句描述:Linq使用Group By返回两个产品序列。第一个序列包含单价大于10的产品。第二个序列包含单价小于或等于10的产品。

说明:按产品单价是否大于10分类。其结果分为两类,大于的是一类,小于及等于为另一类。

转载地址:http://rknll.baihongyu.com/

你可能感兴趣的文章
GNU General Public License v3.0
查看>>
Django:(博客系统)添加文章(中文)出现UnicodeEncodeError乱码
查看>>
Win10 UWP开发:摄像头扫描二维码/一维码功能
查看>>
回声状态网络(ESN)基础教程
查看>>
windows 上rsync客户端使用方法
查看>>
curl 上传文件
查看>>
pcre和正则表达式的误点
查看>>
眼睛问题
查看>>
UWP项目生成安装包远程安装在树莓派上
查看>>
VUE -- ejs模板的书写
查看>>
C++ 中memset 勿要对类使用
查看>>
vue2 axios 接口函数封装
查看>>
总结: 在fc23中, 安装音频mp3 视频flv 的播放插件其实很简单, 只要一步就可以了: dnf install gstreamer1-libav...
查看>>
AI 新技术革命将如何重塑就业和全球化格局?深度解读 UN 报告(中篇)
查看>>
使用subprocess模块调用系统命令
查看>>
集成第三方接口的技巧总结
查看>>
安装CentOS 6停在selinux-policy-targeted卡住的问题解决
查看>>
Mysql初始化root密码和允许远程访问
查看>>
VMPlayer Ubuntu 16.04 Copy and Paste with Host 主机与宿机之间的复制粘贴
查看>>
Ubantu 16.04升级内核版本和还原到升级之前的内核版本的方法
查看>>