如何在 Linq 中执行左外连接? [复制]

Posted

技术标签:

【中文标题】如何在 Linq 中执行左外连接? [复制]【英文标题】:How do I perform a Left Outer Join in Linq? [duplicate] 【发布时间】:2014-09-17 09:12:24 【问题描述】:

我是 Linq 新手,我需要将此查询转换为 DocumentStores 和 Orders 之间的左外连接,因为并非所有文档都与订单相关:

    var documents=(from d in _dataContextOrders .DocumentStores 
                           join o in _dataContextOrders.Orders on d.OrderID equals o.ID
                           join t in _dataContextOrders .DocumentTypes on d.DocumentType equals t.DocTypeID
                       select new
                           
                               d.ID,
                               o.PORef ,
                               t.DocTypeDescription,
                               d.Name,
                               d.ContentType
                           ).ToList();

我如何做到这一点?

【问题讨论】:

你可以查看我写的这篇文章:experts-exchange.com/Programming/Languages/.NET/… 为什么我每天都会看到一个新问题? 【参考方案1】:
from a in dataContext.<tableA>
join _b in dataContext.<tableB> on a.id equals _b.aid into _b
from b in _b.DefaultIfEmpty()
select <whatyouwanttoselect>

如果 id 上的连接失败,b 将为空

【讨论】:

以上是关于如何在 Linq 中执行左外连接? [复制]的主要内容,如果未能解决你的问题,请参考以下文章

如何在 LINQ 中使用左外连接进行 SQL 查询?

LINQ查询中的左外连接[重复]

LINQ to SQL 执行联合和左外连接

Linq To Sql 左外连接 - 过滤空结果

灵巧;如何在多个条件下执行左外连接?

如何使用 Dynamic Linq 进行左外连接?