MySQL中如何将几个没有关系的结果集放在一起
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了MySQL中如何将几个没有关系的结果集放在一起,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1670字,纯文字阅读大概需要3分钟。
内容图文
![MySQL中如何将几个没有关系的结果集放在一起](/upload/InfoBanner/zyjiaocheng/550/a5d98399093247908b526c430eb08668.jpg)
MySQL中如何将几个没有关系的结果集放在一起,刚好b里面的行数最多是没有问题的,但问题是不知道a、b哪个里面的行数最多,解决这个
在做报表的时候,遇到要把类型A的数据和类型B的数据横向放在一个表中展示,两个之间没什么关系,哪个的数据量多也不确定,废了段时间,才折腾出如下的解决方法:
需要将SELECT es.name primary_school ,COUNT(DISTINCT esi.stu_id) primary_num FROM……、SELECT es.name AS high_school,COUNT(DISTINCT esi.stu_id) AS high_num FROM……、SELECT COUNT(DISTINCT esi.stu_id) total_num FROM……的结果放到一起,由于结果之间没什么关系,先给获取到的结果添加编号,SELECT @rownumb:=@rownumb+1 AS rownum, resources.* FROM (SELECT @rownumb:=0) r,(……)resources,然后根据编号将三个结果集合并起来:
SELECT c.rownum,b.high_school,b.high_num,a.primary_school,a.primary_num, c.total_num
FROM
(……) b
LEFT JOIN
(……) a
ON a.rownum = b.rownum
LEFT JOIN
(……) c
ON c.rownum = b.rownum
这个结果如果刚好b里面的行数最多是没有问题的,,但问题是不知道a、b哪个里面的行数最多,解决这个问题,如果可以用full join就可以直接解决了,但full join对于使用的mysql版本不可用,采取的方法是用union all将几个left join后得到的结果合并在一起:
SELECT DISTINCT high_school,high_num,primary_school,primary_num, total_num
FROM
(SELECT c.rownum,b.high_school,b.high_num,a.primary_school,a.primary_num, c.total_num
FROM
(……) b
LEFT JOIN
(……) a
ON a.rownum = b.rownum
LEFT JOIN
(……) c
ON c.rownum = b.rownum
UNION ALL
SELECT c.rownum,b.high_school,b.high_num,a.primary_school,a.primary_num, c.total_num
FROM
(……) a
LEFT JOIN
(……) b
ON a.rownum = b.rownum
LEFT JOIN
(……) c
ON c.rownum = a.rownum
) ee
内容总结
以上是互联网集市为您收集整理的MySQL中如何将几个没有关系的结果集放在一起全部内容,希望文章能够帮你解决MySQL中如何将几个没有关系的结果集放在一起所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。