首页 >数据库 >mysql教程 >为什么我的左外连接只返回两行而不是三十行?

为什么我的左外连接只返回两行而不是三十行?

Susan Sarandon
Susan Sarandon原创
2025-01-23 16:02:11921浏览

Why Does My Left Outer Join Only Return Two Rows Instead of Thirty?

左外连接故障排除:为什么只返回两行

用户尝试使用左外连接计算每日页面浏览量,但查询意外地仅返回两行,而不是预期的三十行。 让我们检查一下有问题的查询及其解决方案。

原始查询:

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

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