- 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
9.8.2查询表达式 3.orderby子句 orderby子句用于对返回的结果进行排序,ascending关键字表示升序,descending关键字表示降序。例如: var query2 = from table2 in context.MyTable2 where table2.性别 == 男 table2.成绩 60 orderby table2.学号 ascending, table2.成绩 descending select table2; 9.8.2 查询表达式 4.group子句 group子句用于按指定的键分组,group后面可以用by指定分组的键。 例如: MyDatabaseClassesDataContext context = new MyDatabaseClassesDataContext( ); var query2 = from table2 in context.MyTable2 orderby table2.学号 ascending, table2.成绩 descending where table2.性别 == 男 table2.成绩 60 group table2 by table2.成绩; 9.8.2查询表达式 5.select子句 select子句用于生成查询结果并指定每个返回的元素的“形状”或类型。 除了前面所举的select子句的用法外,还可以用select子句让范围变量只包含成员的子集,例如查询结果只包含数据表中的一部分字段等。当select子句生成除源元素副本以外的内容时,该操作称为“投影”。 9.8.2 查询表达式 MyDatabaseClassesDataContext context = new MyDatabaseClassesDataContext( ); var query2 = from table2 in context.MyTable2 select table2.成绩; Console.WriteLine(平均值:{0},最大值:{1}, query2.Average( ), query2.Max( )); var query3 = from table2 in context.MyTable2 select new { StudentName = table2.姓名, Grade = table2.成绩 }; 9.8.2 查询表达式 6.join子句 join子句用于将来自不同源序列并且在对象模型中没有直接关系的元素相关联。每个join子句只接受两个源序列,如果有多个源,可以用多个join子句。 9.8.2 查询表达式 三种最常见的联接类型:内部联接、分组联接和左外部联接。 (1)内部联接 内部联接产生一个结果集,对于该结果集内第一个集合中的每个元素,只要在第二个集合中存在一个匹配元素,该元素就会出现一次。如果第一个集合中的某个元素没有匹配元素,则它不会出现在结果集内。 join子句所实现的内部联接就是关系数据库所描述的内部联接。 内部连接举例 var myQuery1 = from table2 in context.MyTable2 join table3 in context.MyTable3 on table2.学号 equals table3.学号 select new { StudentName = table2.姓名, ReleationName = table3.成员姓名, Releation = table3.与本人关系 }; 9.8.2 查询表达式 (2)分组联接 分组联接会产生一个分层的结果序列,该序列将左侧源序列中的元素与右侧源序列中的一个或多个匹配元素相关联。 例如: var myQuery1 = from table2 in context.MyTable2 join table3 in context.MyTable3 on table2.学号 equals table3.学号 into relation select new { StudentName = table2.姓名, Releation = relation }; 9.8.2 查询表达式 (3)左外部联接 左外部联接是这样一个联接:在其中返回第一个集合的每个元素,而无论该元素在第二个集合中是否具有相关元素。可以使用 LINQ,通过对分组联接的结果调用 DefaultIfEmpty 来执
文档评论(0)