因此,常常出现这样的错误
之后,也许有人会用到类似的查询
为什么呢?难道UNION和ORDER BY 不能同时存在?
union和 order by 当然是可以同时存在的
但是在使用union的时候,联合查询不仅仅是将数据集合合并
他并不是将每个子查询一个一个查询出来后联接在一起,数据库是将整段查询语句理解之后统一查询得到的是整个的数据集合
另外order by在一个数据集合查询里也只能出现一次并且出现在最后。
因此,在联合查询里,order by 要写在最后一个子查询之后,并且,该排序是对整个联合查询出来的结果集排序的,并不是只对最后一个子查询排序
再做一个试验来更充分的说明这个问题
创建一个这样的查询
如果联合查询只是但存的将查询结果联接在一起,那么我们得到的结果应该是:42153
但是,实际上得到的结果是和数据库里数据排列的顺序一样的 12345
因此,可以得出结论,联合查询的结果是整个查询完成后得出的,而不是将子查询挨个完成后拼接的。
另外关于TOP?
如果是这样,在普通的查询中,TOP是在ORDER BY之后执行的,那么