首页 >数据库 >mysql教程 >左连接与内连接:WHERE 子句如何影响左连接的结果?

左连接与内连接:WHERE 子句如何影响左连接的结果?

DDD
DDD原创
2025-01-03 18:53:441074浏览

Left Join vs. Inner Join: How Does a WHERE Clause Affect a Left Join's Results?

左联接与内联接

在 SQL 中,左联接和内联接是产生不同结果集的两种基本联接类型。左联接返回左表中的所有行,并根据联接条件匹配右表中的行。如果未找到匹配项,则右表中的缺失值将表示为 NULL。相反,内部联接仅返回满足联接条件的行,排除两个表中不满足该条件的行。

左联接行为修改

中提供的 SQL 查询:

SELECT
a.foo
b.bar
c.foobar
FROM tableOne AS a
INNER JOIN tableTwo AS b ON a.pk = b.fk
LEFT JOIN tableThree AS c ON b.pk = c.fk
WHERE a.foo = 'something'
AND c.foobar = 'somethingelse'

在后面存在 WHERE c.foobar = 'somethingelse' 子句LEFT JOIN 条件具有令人惊讶的效果。它似乎将左联接转换为内联接,如果 tableThree 中不存在“somethingelse”,则不会返回任何行。

解释

这看起来很奇怪行为由 SQL 语句的评估顺序产生。 WHERE 子句在执行连接后进行处理。因此,当在 WHERE 子句中指定 c.foobar = 'somethingelse' 时,它会有效地过滤掉左连接中 c.foobar 为 NULL 的所有行。因此,只有 c.foobar 与指定值('somethingelse')匹配的行才会保留在最终结果集中。

解决方案

保持所需的左连接行为,有两个选项:

  1. 修改 WHERE 子句以包含 OR c.foobar IS NULL,如下所示:

    WHERE a.foo = 'something'
    AND (c.foobar = 'somethingelse' OR c.foobar IS NULL)

    这允许 c.foobar 为 NULL 的行包含在结果集中。

  2. 移动c.foobar = 'somethingelse' 与左连接的 ON 子句进行比较,确保结果中仅包含满足该条件的行设置:

    LEFT JOIN tableThree AS c ON b.pk = c.fk AND c.foobar = 'somethingelse'

以上是左连接与内连接:WHERE 子句如何影响左连接的结果?的详细内容。更多信息请关注PHP中文网其他相关文章!

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