博客
关于我
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/

    你可能感兴趣的文章
    mapping文件目录生成修改
    查看>>
    MapReduce程序依赖的jar包
    查看>>
    mariadb multi-source replication(mariadb多主复制)
    查看>>
    MariaDB的简单使用
    查看>>
    MaterialForm对tab页进行隐藏
    查看>>
    Member var and Static var.
    查看>>
    memcached高速缓存学习笔记001---memcached介绍和安装以及基本使用
    查看>>
    memcached高速缓存学习笔记003---利用JAVA程序操作memcached crud操作
    查看>>
    Memcached:Node.js 高性能缓存解决方案
    查看>>
    memcache、redis原理对比
    查看>>
    memset初始化高维数组为-1/0
    查看>>
    Merge Two Sorted Lists - LeetCode
    查看>>
    Mesos 资源分配
    查看>>
    Metasploit CGI网关接口渗透测试实战
    查看>>
    Metasploit SQL注入漏洞渗透测试实战
    查看>>
    Metasploit Web服务器渗透测试实战
    查看>>
    Metasploit Windows AD渗透测试实战
    查看>>
    MFC之处理消息映射的步骤...
    查看>>
    MFC对话框屏幕居中
    查看>>
    MFC工作笔记0011---atoi的用法
    查看>>