mysql C 将所有记录保存在“WHERE IN()”子句中,即使找不到它们也是如此
发布时间:2023-12-14 14:49:27 所属栏目:MySql 来源:DaWei
导读: 我有以下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,其中
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,其中
我有以下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表选项进行对比. (编辑:鲜蔬坊站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- 使用Sqoop将数据从MySQL导入Hive
- MySQL性能调优:提升数据库性能的策略
- Mysql必读MYSQL无法连接 提示10055错误的解决方法
- Mysql应用mysql获得60天前unix时间思路及代码
- 如何使用QuerySets和MySql“全文搜索”在多个字段中进行Dja
- Mysql学习windows和linux安装mysql后启用日志管理功能的方法
- Mysql必读CentOS 7中源码安装MySQL 5.7.6+详细教程
- sql – 设置LD_BIND_NOW变量以解决TNS Linux错误:29:非法
- MYSQL教程MySQL性能优化之Open_Table配置参数的合理配置建议
- Django从MySQL迁移到Postgres
推荐文章
站长推荐