首页 >后端开发 >C++ >如何使用多条件过滤执行 LINQ to SQL 左外连接?

如何使用多条件过滤执行 LINQ to SQL 左外连接?

DDD
DDD原创
2025-01-04 08:48:34858浏览

How to Perform a LINQ to SQL Left Outer Join with Multi-Condition Filtering?

具有多条件过滤的 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中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn