mysql数据库多个表union all查询并排序的结果为啥错误

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql数据库多个表union all查询并排序的结果为啥错误相关的知识,希望对你有一定的参考价值。

你想法是好的,
不过SQLServer不支持这样操作,
原因是order by 的优先级比 union all要低,所以一旦同时出新order 和 union
会先执行union , 再执行order
参考技术A 首先看下是不是多个用来unoin的sql语句的字段个数不匹配

SQL 中的 UNION 和UNION ALL 有啥区别?

UNION表示“并”,当用的时候,系统会自动将重复的元组去掉,如果要保留重复元组则就用UNION ALL。
楼主,采纳吧!
参考技术A

union 将两个表连接后删除其重复的项。


union all 将两个表连接都不删除其重复的项。

补充资料:


数据库中,UNION和UNION ALL都是将两个结果集合并为一个,但这两者从使用和效率上来说都有所不同。


UNION在进行表链接后会筛选掉重复的记录,所以在表链接后会对所产生的结果集进行排序运算,删除重复的记录再返回结果。实际大部分应用中是不会产生重复的记录,最常见的是过程表与历史表UNION。如:


select * from users1 union select * from user2

这个SQL在运行时先取出两个表的结果,再用排序空间进行排序删除重复的记录,最后返回结果集,如果表数据量大的话可能会导致用磁盘进行排序。


而UNION ALL只是简单的将两个结果合并后就返回。这样,如果返回的两个结果集中有重复的数据,那么返回的结果集就会包含重复的数据了。

从效率上说,UNION ALL 要比UNION快很多,所以,如果可以确认合并的两个结果集中不包含重复的数据的话,那么就使用UNION ALL,如下:


select * from user1 union all select * from user2

参考技术B UNION 会合并重复数据,(由于要合并重复,该操所 隐藏着一个 排序的操作。)
UNION ALL 简单合并,不会合并重复的。
参考技术C 如果我们需要将两个select语句的结果作为一个整体显示出来,我们就需要用到union或者union all关键字。union(或称为联合)的作用是将多个结果合并在一起显示出来。
union和union all的区别是,union会自动压缩多个结果集合中的重复结果,而union all则将所有的结果全部显示出来,不管是不是重复。
Union:对两个结果集进行并集操作,不包括重复行,同时进行默认规则的排序;
Union All:对两个结果集进行并集操作,包括重复行,不进行排序;
参考技术D UNION: 指定合并多个结果集并将其作为单个结果集返回。
ALL: 将全部行并入结果中。其中包括重复行。如果未指定该参数,则删除重复行。

以上是关于mysql数据库多个表union all查询并排序的结果为啥错误的主要内容,如果未能解决你的问题,请参考以下文章

MySQL union all排序问题

mysql 使用UNION ALL问题

MySQL:union all与union区别详解

mysql union all和union的区别

MySQL中使用union all获得并集的排序

按日期排序 UNION ALL 上的选择查询