`

关于 联合查询 UNION 和Order by

 
阅读更多

很多朋友刚使用联合查询UNION的时候常常会理所当然的将联合查询理解为把没一个子查询的结果集组合成一个大的结果集。

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

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

分享到:
评论

相关推荐

    MySQL中union和order by同时使用的实现方法

    MySQL中union和order by是可以一起使用的,但是在使用中需要注意一些小问题,下面通过例子来说明。首先看下面的t1表。 1、如果直接用如下sql语句是会报错:Incorrect usage of UNION and ORDER BY。 SELECT * FROM ...

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

    因此,常常出现这样的错误 代码如下:select * from [IND] where INDID&gt;10unionselect * from [IND] where INDID&lt;9&gt;10 order by INDID descunionselect * from [IND] where ...难道UNION和ORDER BY 不能同时存在? union

    sqlserver union

    理解其工作原理和最佳实践,可以帮助你更有效地管理和查询数据库。记住,选择正确的操作符(`UNION`或`UNION ALL`)以及优化查询是提升数据库性能的关键。通过持续学习和实践,你将能够熟练掌握这些技能,成为数据库...

    MySQL利用UNION连接2个查询排序失效详解

    这导致了查询1和查询2各自独立排序,但最终的联合结果并没有按任何特定顺序排列。 如果需要对整个合并后的结果集进行排序,有两种常见的解决方法: 1. **使用子查询**: 我们可以把每个`UNION`或`UNION ALL`的子...

    MySQL 通过索引优化含ORDER BY的语句

    以下是一些关于如何利用索引来优化`ORDER BY`语句的知识点: 1. **合理创建索引**:索引可以显著提高数据读取速度,但不是所有列都需要创建索引。应根据查询需求来决定哪些列需要索引。创建过多的索引会影响写操作...

    MySQL查询优化:连接查询排序limit(join、order by、limit语句)介绍

    在MySQL查询优化中,连接查询(join)与排序(order by)和限制返回结果的数量(limit)是常见的操作,但当它们结合在一起时,可能会导致性能下降。这个问题在标题和描述中已经阐述得很清楚,主要涉及到如何高效地...

    sql语言手册 和联合查询

    根据提供的文件信息,我们将深入探讨SQL语言的基本概念及其在数据操作中的应用,特别是SELECT、INSERT、UPDATE等核心命令,以及ORDER BY和GROUP BY等高级功能的使用方法。 ### SQL语言概述 SQL(Structured Query ...

    sql联合 模糊查询

    这一主题涵盖了SQL中的JOIN操作、模糊查询(LIKE语句)以及ORDER BY排序,是数据库管理与数据分析领域的重要技能。 ### SQL联合查询(UNION) 在SQL中,联合查询(UNION)允许我们合并两个或更多SELECT语句的结果...

    SQL联合统计查询

    在SQL(Structured Query Language)中,联合统计查询是数据库管理中的一个重要概念,它涉及到如何从多个数据表中提取并合并信息,然后进行聚合计算。在实际业务场景中,如报表统计,这种查询方法非常常见,尤其在...

    SQL查询语句精华使用简要(2)

    本文将深入探讨SQL查询语句中的关键元素,包括WHERE子句、ORDER BY子句、联合查询以及连接查询。 首先,WHERE子句是用于设置查询条件的关键部分,它过滤掉不符合特定条件的记录。例如,`SELECT * FROM usertable ...

    sql 查询结果合并union all用法_数据库技巧

    select * from A union select * from B –不合并重复行 select * from A union all select * from B 按某个字段排序 –合并重复行 select * from ( select * from A union select * from B) AS T order by 字段名 ...

    计算机病毒与防护:MYSQL联合查询上.ppt

    例如,通过在SELECT语句末尾添加ORDER BY N,如果N超出实际列数,查询会失败,导致页面显示异常。攻击者通过逐渐增加N的值,可以确定结果集的列数。 6. **判断列输出**:在某些情况下,不是所有的查询结果都会显示...

    贷齐乐系统最新版SQL注入(无需登录绕过WAF可union select跨表查询)

    - 数据提取:使用UNION SELECT、ORDER BY等方法提取数据。 - 控制流程:可能的话,执行数据库操作,如删除、修改数据。 6. **修复策略**:一旦发现SQL注入漏洞,应立即更新受影响的代码,使用参数化查询,增强...

    SQL SERVER 2000查询语句

    1. **联合查询(UNION)**: 联合查询用于合并两个或多个SELECT语句的结果集。只有当所有SELECT语句选择相同数量的列,并且列的数据类型兼容时,才能使用UNION。例如,你可以用以下方式获取表A和表B中所有不同的值...

    T-SQL高级查询

    exists和not exists查询需要内部查询和外部查询进行一个关联的条件,如果没有这个条件将是查询到的所有信息。如:id等于student.id; # some、any、all子句查询示例 查询班级的学生年龄大于班级的学生的年龄的...

    mysql多表联合查询操作实例分析

    MySQL的多表联合查询是数据库操作中非常重要的一个概念,特别是在处理复杂的数据关系时,能够有效地从多个表中提取所需...在实际应用中,应根据数据关系和查询需求选择最适合的方法,以优化查询性能和结果的准确性。

    SQL各种查询方法

    8. **分页查询**:通过`OFFSET`和`FETCH NEXT`关键字实现分页,例如`SELECT * FROM 表名 ORDER BY 列名 OFFSET 50 ROWS FETCH NEXT 10 ROWS ONLY`,这将返回第51到60条记录。 9. **存在查询**:`EXISTS`子句用于...

Global site tag (gtag.js) - Google Analytics