SELECT id,sum(views) as total_views
FROM table
WHERE id IN (1,2,3)
GROUP BY id
ORDER BY total_views ASC
如果在数据库中只找到id 1,3,我仍然希望出现id 2,其中total_views设置为0.
有没有办法做到这一点?这不能使用任何其他表.
最佳答案
这里是迈克尔解决方案的替代方案(不是一个糟糕的解决方案,请注意 – 即使是“很多”的ID),只要你不是在查询群集.
原文链接:https://www.f2er.com/mysql/433652.htmlcreate temporary table __ids (
id int unsigned primary key
) engine=MEMORY;
insert into __ids (id) values
(1),(2),(3)
;
SELECT table.id,sum(views) as total_views
FROM __ids left join table using (id)
GROUP BY table.id
ORDER BY total_views ASC
如果你的查询变得复杂,我甚至可以设想它以这种方式更高效地运行.但是,如果我是你,我会使用真实数据将此选项与Michael的ad-hoc UNION’ed表选项进行对比.