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 要写在一个子查询之后,并且,该排序是对整个联合查询出来的结果集排序的,并不是只对一个子查询排序
union
select from [IND] where INDID<9 order by INDID desc
这样就可以对我们联合查询出来的结果集进行整体排序,而不是只对一个子查询的结果集排序。
再做一个试验来更充分的说明这个问题
创建一个这样的查询 union select from [IND] where INDID=2
select from [IND] where INDID=4
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截取集和数量,那么自然联合查询分页等其他应用也不在话下了
编程语言
- 甘肃哪有关键词排名优化购买方式有哪些
- 甘肃SEO如何做网站优化
- 河南seo关键词优化怎么做电话营销
- 北京SEO优化如何做QQ群营销
- 来宾百度关键词排名:提升您网站曝光率的关键
- 卢龙关键词优化:提升您网站排名的策略与技巧
- 山东网站优化的注意事项有哪些
- 四川整站优化怎样提升在搜索引擎中的排名
- 疏附整站优化:提升网站性能与用户体验的全新
- 海南seo主要做什么工作售后服务要做到哪些
- 荣昌百度网站优化:提升您网站的搜索引擎排名
- 河北seo网站排名关键词优化如何做SEO
- 江西优化关键词排名推广售后保障一般有哪些
- 古浪SEO优化:提升你的网站可见性
- 西藏网站排名优化怎么把网站排名在百度首页
- 如何提升阳东百度快照排名:详尽指南