大佬教程收集整理的这篇文章主要介绍了如何合并 SQL 查询的两个结果,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在尝试将两个 sql 查询的结果合并为一个
查询 1:
SELECT COUNT(class) as show,year
FROM lee
where class = 'Show'
GROUP BY year
结果
show year
185 2016
296 2020
655 2019
查询 2
SELECT COUNT(class) as movIE,year
FROM lee
where class = 'movIE'
GROUP BY year
结果
movIE year
556 2016
987 2020
690 2019
我如何实现这样的目标:
movIE show year
556 185 2016
987 296 2020
690 655 2019
您可以使用 case when
语句选择计数类。
SELECT count(CASE WHEN class = 'movie' THEN 1 END) as movie,count(CASE WHEN class = 'show' THEN 1 END) as show,year
FROM lee
GROUP BY year;
,
使用条件聚合:
SELECT sum(cASE WHEN class = 'show' THEN 1 ELSE 0 END) as show,sum(cASE WHEN class = 'movie' THEN 1 ELSE 0 END) as movie,year
FROM lee
GROUP BY year;
,
我的解决方案不是最漂亮的,但它是给另一个选择
SELECT m.movie,s.show,m.YEAR FROM
(SELECT count(1) AS movie,YEAR FROM LEE WHERE CLASS = 'movie' GROUP BY YEAR) m
JOIN (SELECT count(1) AS show,YEAR FROM LEE WHERE CLASS = 'show' GROUP BY YEAR) s
ON (s.YEAR = m.YEAR);
以上是大佬教程为你收集整理的如何合并 SQL 查询的两个结果全部内容,希望文章能够帮你解决如何合并 SQL 查询的两个结果所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。