具有多条件过滤的 LINQ to SQL 左外连接
在 LINQ to SQL 中,左外连接允许检索所有左表中的记录,即使右表中没有匹配的记录。使用左外连接进行查询时,可能需要对连接表应用额外的过滤条件。
考虑以下 SQL 语句:
SELECT f.value FROM period AS p LEFT OUTER JOIN facts AS f ON p.id = f.periodid AND f.otherid = 17 WHERE p.companyid = 100
此查询从“facts”表中的每条记录都包含在“period”表中,即使“facts”表中没有匹配的记录。此外,它还应用了进一步的过滤器,仅包含“facts”表中“otherid”列等于 17 的记录。
要将此查询转换为 LINQ,可以执行以下步骤:
var query = from p in context.Periods join f in context.Facts on p.id equals f.periodid into fg from fgi in fg.Where(f => f.otherid == 17).DefaultIfEmpty() where p.companyid == 100 select f.value;
与标准左外连接的主要区别在于,在调用 DefaultIfEmpty() 之前,在连接表“fg”上使用Where() 方法。这确保了在由于空连接结果而可能排除任何记录之前应用附加过滤条件。
另一种方法涉及使用子查询:
var query = from p in context.Periods join f in context.Facts on p.id equals f.periodid into fg from fgi in (from f in fg where f.otherid == 17 select f).DefaultIfEmpty() where p.companyid == 100 select f.value;
这两种方法都实现了使用多个连接条件执行左外连接的期望结果。重要的是要了解,在 JOIN 之后的 WHERE 子句中放置附加过滤条件可能不会产生所需的行为,因为它可能会导致排除由于左外连接而应包含的记录。
以上是如何使用多条件过滤执行 LINQ to SQL 左外连接?的详细内容。更多信息请关注PHP中文网其他相关文章!