|
|
51CTO旗下网站
|
|
移动端

Linq实现Left join

这里介绍linq实现Left join,students 表中有 字段 No,Name.book 表中有 bookName,borroeStudentNo(借书人的编号)现在要得到所有书籍信息,包括书的借阅人的信息。这里就需要left join。

作者:佚名来源:IT168|2009-09-16 17:07

本文向大家介绍linq实现Left join,可能好多人还不了解Left join,没有关系,看完本文你肯定有不少收获,希望本文能教会你更多东西。

在linq中没有 left join,所以当希望用到时,会比较范难。以下是linq实现Left join的方法。

students 表中有 字段 No,Name.book 表中有 bookName,borroeStudentNo(借书人的编号)现在要得到所有书籍信息,包括书的借阅人的信息。这里就需要left join。

  1. var sqlresult = from b in book  
  2. joins in students on b.borroeStudentNoequalss.No intobs  
  3. from bb in bs.DefaultIfEmpty()  
  4. select new  
  5. {  
  6. b.bookName,  
  7. s.No,  
  8. s.Name  
  9. }; 

***linq实现Left join

最近有发现了个问题,当查询源是两个List的时候,上面的做法会在当右边的结果为空的时候报错。也就是上面的书的借阅人为空的时候。强调:查询源是两个List的时候,而不是数据表

更改为:

  1. select new  
  2. {  
  3. b.bookName,  
  4. SNo = s==null?"":s.No,  
  5. SName = s==null?"":s.Name  
  6. }; 

【编辑推荐】

  1. LINQ Customers类概括
  2. LINQ查询操作全面分析
  3. LINQ to SQL的Table剖析
  4. Linq数据分组全面描述
  5. LINQ查询基础概括
【责任编辑:志京 TEL:(010)68476606】

点赞 0
分享:
大家都在看
猜你喜欢

订阅专栏+更多

16招轻松掌握PPT技巧

16招轻松掌握PPT技巧

GET职场加薪技能
共16章 | 晒书包

276人订阅学习

20个局域网建设改造案例

20个局域网建设改造案例

网络搭建技巧
共20章 | 捷哥CCIE

643人订阅学习

WOT2019全球人工智能技术峰会

WOT2019全球人工智能技术峰会

通用技术、应用领域、企业赋能三大章节,13大技术专场,60+国内外一线人工智能精英大咖站台,分享人工智能的平台工具、算法模型、语音视觉等技术主题,助力人工智能落地。
共50章 | WOT峰会

0人订阅学习

读 书 +更多

Linux指令速查手册

Linux是一款开源的操作系统,得到了广大开发者的青睐。掌握Linux系统的指令及其用法是学习Linux系统的基础。本书详细地介绍了常用Linux指令...

订阅51CTO邮刊

点击这里查看样刊

订阅51CTO邮刊

51CTO服务号

51CTO播客