mysql – 将所有记录保存在“WHERE IN()”子句中,即使找不到它们也是如此

发布时间:2019-07-16 发布网站:脚本之家
脚本之家收集整理的这篇文章主要介绍了mysql – 将所有记录保存在“WHERE IN()”子句中,即使找不到它们也是如此脚本之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

我有以下mysql查询:

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),只要你不是在查询群集.

create 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表选项进行对比.

总结

以上是脚本之家为你收集整理的mysql – 将所有记录保存在“WHERE IN()”子句中,即使找不到它们也是如此全部内容,希望文章能够帮你解决mysql – 将所有记录保存在“WHERE IN()”子句中,即使找不到它们也是如此所遇到的程序开发问题。

如果觉得脚本之家网站内容还不错,欢迎将脚本之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:76874919,请注明来意。

脚本之家官方公众号

微信公众号搜索 “ 程序精选 ” ,选择关注!

微信公众号搜索 “ 程序精选 ” ,选择关注!
精选程序员所需精品干货内容!

标签:mysql