我目前正在尝试从一个具有全局统计信息的表中获取一个对象,包括第二个表中的每日统计信息。为此,我使用以下连接查询,只要 statsTable 包含 ' oID
' 和 ' Date
' 列的匹配行,它就可以工作。
SELECT
o.ID as ID,
o.Image as Image,
o.Text as `Text`,
o.Views as `Views`,
o.Clicks as Clicks,
COALESCE(s.Views, 0) as DayViews,
COALESCE(s.Clicks, 0) as DayClicks
FROM objectTable o
LEFT JOIN statsTable s
ON o.ID = s.oID
WHERE o.userID = 1
AND DATEDIFF(CURDATE(), s.Date) < 1
LIMIT 1
即使 statsTable 不包含匹配的行,我如何更改查询以获取结果行?
查询不会给出错误,我只是不希望它返回空结果,因为我确信 objectTable 中有数据。
您只需要将s
表上的条件移动到 ON
子句中:
SELECT o.ID as ID, o.Image as Image, o.Text as `Text`,
o.Views as `Views`, o.Clicks as Clicks,
COALESCE(s.Views, 0) as DayViews,
COALESCE(s.Clicks, 0) as DayClicks
FROM objectTable o LEFT JOIN
statsTable s
ON o.ID = s.oID AND DATEDIFF(CURDATE(), s.Date) < 1
WHERE o.userID = 1 ;
LEFT JOIN
保留第一个表中的所有行,而不管 ON
子句的计算结果是否为 true。 第二个表中的列NULL
不匹配的行 -- 然后WHERE
子句会筛选掉这些行。
因此,第一个表上的条件应位于WHERE
子句中。 后续表的条件应在ON
子句中 -- 对于LEFT JOIN
。