博客
关于我
mysql union orderby 无效
阅读量:795 次
发布时间:2023-02-10

本文共 1047 字,大约阅读时间需要 3 分钟。

MySQL中的UNION和ORDER BY命令有一些使用上的限制,特别是在使用UNION时,不能直接在每个SELECT子句中使用ORDER BY。如果需要对多个结果集进行排序,必须将每个子句分别用括号括起来,并在UNION后的结果集中使用ORDER BY。但需要注意的是,直接在子句中使用ORDER BY会导致语法错误。

错误示例:

SELECT * FROM `table_201604` ORDER BY `REPORT_TIME` DESCUNION ALLSELECT * FROM `table_201605` ORDER BY `REPORT_TIME` DESC

这个SQL语句会报错“Incorrect usage of UNION and ORDER BY”,因为没有将每个子句用括号包裹。

正确使用方法:

为了解决这个问题,可以将每个子句用括号包裹,然后在UNION后的结果集中使用ORDER BY:

(SELECT * FROM `table_201604` ORDER BY `REPORT_TIME` DESC)UNION ALL(SELECT * FROM `table_201605` ORDER BY `REPORT_TIME` DESC)

然而,这种方法仍然有问题,因为ORDER BY只能应用在UNION后的整个结果集中,而不能在每个子句中单独应用。

正确的做法:

为了对每个子句分别进行排序,可以使用LIMIT来限制每个子句的结果集数量,然后在UNION之后对整个结果集进行排序:

(SELECT * FROM `table_201604` ORDER BY `REPORT_TIME` DESC LIMIT 5)UNION ALL(SELECT * FROM `table_201605` ORDER BY `REPORT_TIME` DESC LIMIT 5)

这样,每个子句都会按REPORT_TIME字段降序排列,并且最终结果集会合并并按REPORT_TIME字段排序。

关键点总结:

  • 括号使用:每个子句可以使用括号包围,但第一个子句使用括号时,其他子句也必须使用括号包围。
  • ORDER BY的位置:UNION后的整个结果集可以使用ORDER BY,但不能在每个子句中单独使用。
  • LIMIT的使用:如果需要对子句进行排序,可以使用LIMIT限制结果集的大小。
  • 通过以上方法,可以正确使用UNION和ORDER BY命令来对多个结果集进行排序和合并。

    转载地址:http://wgffk.baihongyu.com/

    你可能感兴趣的文章
    Mysql InnoDB 数据更新导致锁表
    查看>>
    Mysql Innodb 锁机制
    查看>>
    MySQL InnoDB中意向锁的作用及原理探
    查看>>
    MySQL InnoDB事务隔离级别与锁机制深入解析
    查看>>
    Mysql InnoDB存储引擎 —— 数据页
    查看>>
    Mysql InnoDB存储引擎中的checkpoint技术
    查看>>
    Mysql InnoDB存储引擎中缓冲池Buffer Pool、Redo Log、Bin Log、Undo Log、Channge Buffer
    查看>>
    MySQL InnoDB引擎的锁机制详解
    查看>>
    Mysql INNODB引擎行锁的3种算法 Record Lock Next-Key Lock Grap Lock
    查看>>
    mysql InnoDB数据存储引擎 的B+树索引原理
    查看>>
    mysql innodb通过使用mvcc来实现可重复读
    查看>>
    mysql insert update 同时执行_MySQL进阶三板斧(三)看清“触发器 (Trigger)”的真实面目...
    查看>>
    mysql interval显示条件值_MySQL INTERVAL关键字可以使用哪些不同的单位值?
    查看>>
    Mysql join原理
    查看>>
    MySQL JOIN原理
    查看>>
    MySQL Join算法与调优白皮书(二)
    查看>>
    Mysql order by与limit混用陷阱
    查看>>
    Mysql order by与limit混用陷阱
    查看>>
    mysql order by多个字段排序
    查看>>
    MySQL Order By实现原理分析和Filesort优化
    查看>>