左外连接故障排除:为什么只返回两行
用户尝试使用左外连接计算每日页面浏览量,但查询意外地仅返回两行,而不是预期的三十行。 让我们检查一下有问题的查询及其解决方案。
原始查询:
<code class="language-sql">SELECT day.days, COUNT(*) AS opens FROM day LEFT OUTER JOIN tracking ON day.days = DAY(FROM_UNIXTIME(open_date)) WHERE tracking.open_id = 10 GROUP BY day.days;</code>
问题:JOIN 之后的 WHERE 子句
问题在于WHERE tracking.open_id = 10
子句。 此条件应用于左外连接之后。 左外连接旨在包含左表 (day
) 中的所有行,即使右表 (tracking
) 中没有匹配项。但是,WHERE
子句有效地过滤掉 tracking.open_id
不为 10 的任何行,从而消除 day
表中在 tracking
中缺少 open_id = 10
对应条目的行。
解决方案:将条件集成到 JOIN
要从 day
表中检索所有 30 行,过滤条件需要是连接条件本身的一部分。 这是使用 AND
实现的:
<code class="language-sql">SELECT day.days, COUNT(tracking.open_id) AS opens FROM day LEFT OUTER JOIN tracking ON day.days = DAY(FROM_UNIXTIME(open_date)) AND tracking.open_id = 10 GROUP BY day.days;</code>
请注意对 COUNT(tracking.open_id)
的更改:这可确保 tracking
中没有匹配条目的日期计数为 0,而不是 NULL,否则会导致某些数据库系统出现问题。 此更正后的查询正确执行左外连接并返回预期的 30 行,准确地表示每日页面打开情况。
以上是为什么我的左外连接只返回两行而不是三十行?的详细内容。更多信息请关注PHP中文网其他相关文章!