≡
  • 网络编程
  • 数据库
  • CMS技巧
  • 软件编程
  • PHP笔记
  • JavaScript
  • MySQL
位置:首页 > 数据库 > MySQL

MySQL联合查询UNION和Order by同时使用报错问题的解决办法

人气:375 时间:2020-07-09

这篇文章主要为大家详细介绍了MySQL联合查询UNION和Order by同时使用报错问题的解决办法,具有一定的参考价值,可以用来参考一下。

感兴趣的小伙伴,下面一起跟随四海网的小编小韵来看看吧!

因此,常常出现这样的错误

代码如下:



select * from [IND] where INDID>10
union
select * from [IND] where INDID<9

目前为止,还没有出现问

 

之后,也许有人会用到类似的查询

代码如下:



select * from [IND] where INDID>10 order by INDID desc
union
select * from [IND] where INDID<9 order by INDID desc

此时就出现问题了,数据库报错。问题就出在order by上

 

为什么呢?难道UNION和ORDER BY 不能同时存在?

union和 order by 当然是可以同时存在的

但是在使用union的时候,联合查询不仅仅是将数据集合合并
他并不是将每个子查询一个一个查询出来后联接在一起,数据库是将整段查询语句理解之后统一查询得到的是整个的数据集合
另外order by在一个数据集合查询里也只能出现一次并且出现在最后。
因此,在联合查询里,order by 要写在最后一个子查询之后,并且,该排序是对整个联合查询出来的结果集排序的,并不是只对最后一个子查询排序

代码如下:


select * from [IND] where INDID>10
union
select * from [IND] where INDID<9 order by INDID desc

这样就可以对我们联合查询出来的结果集进行整体排序,而不是只对最后一个子查询的结果集排序。

 

再做一个试验来更充分的说明这个问题

创建一个这样的查询

代码如下:



select * from [IND] where INDID=4

 

union

select * from [IND] where INDID=2
union
select * from [IND] where INDID=1
union
select * from [IND] where INDID=5
union
select * from [IND] where INDID=3


INDID是主键,在创建数据的时候,数据库里的顺序是12345

 


如果联合查询只是但存的将查询结果联接在一起,那么我们得到的结果应该是:42153

但是,实际上得到的结果是和数据库里数据排列的顺序一样的 12345

因此,可以得出结论,联合查询的结果是整个查询完成后得出的,而不是将子查询挨个完成后拼接的。

代码如下:



select * from [IND] where INDID=4

 

union

select * from [IND] where INDID=2
union
select * from [IND] where INDID=1
union
select * from [IND] where INDID=5
union
select * from [IND] where INDID=3

order by INDID ASC/DESC


这样就可以对整个联合结果集进行排寻了。

 


另外关于TOP?

如果是这样,在普通的查询中,TOP是在ORDER BY之后执行的,那么

代码如下:



select TOP 2 * from [IND] where INDID=4

 

union

select * from [IND] where INDID=2
union
select * from [IND] where INDID=1
union
select * from [IND] where INDID=5
union
select * from [IND] where INDID=3

order by INDID


这样是不是可以得到整个结果集排序后的最前面两条数据呢?

 

答案是不可以。

虽然说在单句的查询中,TOP是在ORDER BY 之后执行,但是在联合查询中,这样写,TOP的作用域是在子查询里,因此TOP并没有对联合查询的结果集筛选,而只对它所写在的那条子查询里进行筛选,这就像是子查询里的WHERE语句一样,类似这样的筛选作用范围都是在子查询,不像ORDER BY 作用在整个联合查询。


那么如何对联合查询进行 截取置顶N条数据的筛选呢? 很简单

用 rowcount

比起TOP来说,rowcount作为结果集截取置顶更加规范些,毕竟不是依靠查询语句,而是直接设置查询语句获得结果集的数目。

代码如下:



set rowcount 2

 

select * from [IND] where INDID=4

union
select * from [IND] where INDID=1
union
select * from [IND] where INDID=2

union
select * from [IND] where INDID=3

order by INDID ASC


形如以上查询语句。我们就可以做到对联合查询排序,并获得最上的两条数据了。

 


既然能利用order by 排序 和 并用rowcount截取集和数量,那么自然联合查询分页等其他应用也不在话下了

本文来自:http://www.q1010.com/177/9501-0.html

注:关于MySQL联合查询UNION和Order by同时使用报错问题的解决办法的内容就先介绍到这里,更多相关文章的可以留意四海网的其他信息。

关键词:MYSQL

您可能感兴趣的文章

  • MySQL把一个表某个字段的内容复制到另一张表的某个字段的SQL语句写法
  • MySQL的group_concat函数使用示例
  • MySQL导入sql文件命令和MySQL远程登陆使用分析
  • MySQL Hash索引和B-Tree索引的区别
  • MySQL优化之表结构优化的5大建议(数据类型选择讲的很好)
  • MySQL WorkBench管理操作MySQL教程
  • MySQL数据库sql优化原则(经验总结)
  • MySQL数据类型varchar分析
  • 使用MySQL事件调度器定时删除binlog
  • MySQL 强大的trim() 函数
上一篇:MySQL联合查询UNION和UNION ALL的使用介绍
下一篇:MySQL把一个表某个字段的内容复制到另一张表的某个字段的SQL语句写法
热门文章
  • mysql 修改character_set_server为utf-8的简单示例
  • 解决MySQL丢失文件localhost.localdomain.pid、mysql.sock的示例
  • MySQL 数据类型binary和varbinary的简单示例
  • MySQL:reading initial communication packet问题解决方法
  • MySql 表类型MYISAM、InnoDB区别
  • bash: mysql: command not found 的解决方法
  • MYSQL默认用户名ROOT修改方法
  • MySQL 常用命令菜鸟教程
  • MySQL 使用命令行新建用户并授予权限
  • MySql 数据库物理文件存放位置查看示例
  • 最新文章
    • MySQL查看死锁与解除死锁的简单示例
    • MySQL 慢查询的功能实例
    • MySQL查看死锁与去除死锁的简单示例
    • MySQL找出未提交事务的SQL的简单示例
    • MySQL锁阻塞的的简单示例
    • MySQL中的binary类型使用操作的示例
    • SQL优化教程之in与range查询的简单示例
    • MySQL 的 21 个规范、优化最佳实践!
    • MySQL 字符类型大小写敏感的简单示例
    • 解决mybatis-plus分页传入参数后sql where条件没有limit分页信息的问题

四海网收集整理一些常用的php代码,JS代码,数据库mysql等技术文章。