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

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

DDD
发布: 2025-01-04 08:48:34
原创
856 人浏览过

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中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板