`
liaobuzhisi
  • 浏览: 71693 次
  • 性别: Icon_minigender_1
  • 来自: 佛山
文章分类
社区版块
存档分类
最新评论

如何联合使用Union和Order by

SQL 
阅读更多

如果使用类似下面的SQL语句:

select columnA, columnB from tableA where columnA = 'Condition 1'
union
select columnC, columnD from tableB where columnC = 'Condition 1'
order by columnA asc

 系统会报错:
消息 207,级别 16,状态 1,第 4 行
列名 'columnA' 无效。
消息 104,级别 16,状态 1,第 4 行
如果该语句包含 UNION、INTERSECT 或 EXCEPT 运算符,则 ORDER BY 项必须出现在选择列表中。

问题原因:
既然把多行给union了,把每列叫成什么名字都是不妥当的。。。只要采用列的序号即可。

select columnA, columnB from tableA where columnA = 'Condition 1'
union
select columnC, columnD from tableB where columnC = 'Condition 1'
order by 2 asc

这里需要注意的是,序号从1开始,如果指定的序号不在允许的范围内,系统会报出一个异常:

select columnA, columnB from tableA where columnA = 'Condition 1'
union
select columnC, columnD from tableB where columnC = 'Condition 1'
order by 4 asc

会报错:
消息 108,级别 16,状态 1,第 1 行
ORDER BY 位置号 4 超出了选择列表中项数的范围。
消息 104,级别 16,状态 1,第 1 行
如果该语句包含 UNION、INTERSECT 或 EXCEPT 运算符,则 ORDER BY 项必须出现在选择列表中。

分享到:
评论

相关推荐

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

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

    union all与order by用法

    在 Oracle PL/SQL 中, UNION ALL 和 ORDER BY 的使用需要遵循一定的规则和限制。本文将详细介绍 UNION ALL 和 ORDER BY 的用法,并通过实例解释其应用场景。 UNION ALL 的用法 UNION ALL 用于合并两个或多个 ...

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

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

    SQL语句 UNION 和 UNION ALL 使用

    - `ORDER BY` 和 `COMPUTE` 子句只能应用于整个 `UNION` 或 `UNION ALL` 的结果集,不能分别应用于每个单独的 `SELECT` 语句。 - 示例正确用法: ```sql SELECT * FROM ( SELECT AID, AName, ADemo FROM ATable ...

    SQL Server2008 Order by在union子句不可直接使用的原因详解

    在SQL Server 2008中,`UNION` 子句用于合并两个或多个 `SELECT` 语句的结果集,但不允许直接在 `UNION` 子句内部使用 `ORDER BY`。这是因为 `ORDER BY` 通常用于对查询结果进行排序,而 `UNION` 的目的是合并不同的...

    union和union All的区别.md

    如果想要在 UNION 中使用 ORDER BY 对结果集进行排序,需要将 ORDER BY 子句放在最后一个查询语句的后面。这是因为 ORDER BY 对整个结果集进行排序,而最后一个查询的结果集是最终结果集的一部分,只有在最后一个...

    MySQL中Union子句不支持order by的解决方法

    在MySQL中,了解如何正确地使用`UNION`和`ORDER BY`对于编写高效的查询至关重要。此外,熟悉其他数据库系统的行为也很重要,因为不同数据库可能有不同的处理方式。在实际应用中,我们还应该考虑性能因素,因为嵌套...

    sqlserver union

    3. **排序结果**:`UNION`后的结果默认无序,如果需要排序,可以添加`ORDER BY`子句,但注意`ORDER BY`只能放在所有`SELECT`语句的最后。 ```sql SELECT ProductID, ProductName FROM Products1 ORDER BY ...

    SQL语句中UNION子句的使用.pdf

    2. 使用UNION子句时,需要注意查询结果的输出顺序,可以使用ORDER BY子句来指定输出顺序。 3. 在使用UNION子句时,需要注意查询结果的输出字段类型和宽度,避免出现输出字段类型和宽度不一致的情况。 UNION子句是...

    order_by_、group_by_、having的用法区别.doc

    在SQL查询语言中,`ORDER BY`, `GROUP BY`, 和 `HAVING` 是三个非常重要的概念,它们分别用于对查询结果进行排序、分组以及在分组后进一步筛选数据。这些操作对于数据分析和报表制作来说至关重要。 #### 二、ORDER ...

    MySQL如何使用union all获得并集排序

    在MySQL中,`UNION ALL` 用于合并多个`...同时,理解如何在`UNION ALL`操作中嵌套`ORDER BY`子句,对于编写复杂查询至关重要。这种技术在处理多条件排序和复杂数据组合时非常实用,能够灵活地适应不断变化的业务需求。

    Sql中的UNION

    - **排序结果**:可以通过添加`ORDER BY`子句对结果进行排序。 - **条件过滤**:可以使用`WHERE`子句对原始数据进行过滤后再使用`UNION`。 - **组合多表**:可以同时使用多个`UNION`操作符连接多个`SELECT`语句。 ...

    Oracle集合操作函数union、intersect、minus.docx

    在使用集合操作符时,可以使用 ORDER BY 子句对结果集进行排序。例如: SELECT id, name FROM worker UNION ALL SELECT empno, ename FROM emp ORDER BY name; 在上面的例子中,ORDER BY 子句将对合并后的结果集...

    SQLServer中Partition By及row_number 函数使用详解

    下面是一个具体的示例,展示了如何创建和使用 `PARTITION BY` 和 `ROW_NUMBER()`: ```sql CREATE TABLE TESTDB(A VARCHAR(8), B VARCHAR(8)); INSERT INTO TESTDB SELECT 'A1', 'B1' UNION ALL SELECT 'A1', 'B2' ...

    Oracle 语法之 OVER (PARTITION BY ..) 及开窗函数(转载)

    这里,`PARTITION BY class` 表示按 `class` 分区,`ORDER BY s DESC` 则是在每个分区内按照 `s` 的降序排列。结果会显示每个分区中 `s` 值最大的记录。 ##### 2. 开窗函数的类型 开窗函数包括但不限于 `SUM`, `...

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

    6. **WHERE + ORDER BY + LIMIT组合优化**:为`WHERE`和`ORDER BY`的列创建联合索引可以进一步提升效率。例如: ```sql SELECT [column1],[column2],…. FROM [TABLE] WHERE [columnX] = [value] ORDER BY [sort] ...

Global site tag (gtag.js) - Google Analytics