左联接与内联接
在 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')匹配的行才会保留在最终结果集中。
解决方案
保持所需的左连接行为,有两个选项:
修改 WHERE 子句以包含 OR c.foobar IS NULL,如下所示:
WHERE a.foo = 'something' AND (c.foobar = 'somethingelse' OR c.foobar IS NULL)
这允许 c.foobar 为 NULL 的行包含在结果集中。
移动c.foobar = 'somethingelse' 与左连接的 ON 子句进行比较,确保结果中仅包含满足该条件的行设置:
LEFT JOIN tableThree AS c ON b.pk = c.fk AND c.foobar = 'somethingelse'
以上是左连接与内连接:WHERE 子句如何影响左连接的结果?的详细内容。更多信息请关注PHP中文网其他相关文章!