ASP源码.NET源码PHP源码JSP源码JAVA源码DELPHI源码PB源码VC源码VB源码Android源码
当前位置:首页 >> 数据库 >> MySql >> Mysql联合查询UNION和Order by同时使用报错问题的解决办法

Mysql联合查询UNION和Order by同时使用报错问题的解决办法(2/2)

来源:网络整理     时间:2016-06-21     关键词:

本篇文章主要介绍了" Mysql联合查询UNION和Order by同时使用报错问题的解决办法",主要涉及到方面的内容,对于MySql感兴趣的同学可以参考一下: 因此,常常出现这样的错误复制代码 代码如下:select * from [IND] where INDID>10unionselect * from [I...

如果是这样,在普通的查询中,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截取集和数量,那么自然联合查询分页等其他应用也不在话下了

以上就介绍了 Mysql联合查询UNION和Order by同时使用报错问题的解决办法,包括了方面的内容,希望对MySql有兴趣的朋友有所帮助。

本文网址链接:http://www.codes51.com/article/detail_1896349_2.html

相关图片

相关文章