• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >Mysql > MySQL中Union子句不支持order by的解决方法_MySQL

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

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-12-05

匿名通过本文主要向大家介绍了MySQL,Union子句,order,by,解决等相关知识,希望本文的分享对您有所帮助
本文实例讲述了MySQL中Union子句不支持order by的解决方法。分享给大家供大家参考,具体如下:

我对DB知之甚少,这问题只在MySQL遇到,不知道别的DBMS是不是也如此。

问题是这样的,我打算在一个表里获得与某一行记录相邻的两行,并且想通过union一起取出来,所以这么写:

select id,title from subjects where id>#some_id# order by id limit 1
union
select id,title from subjects where id<#some_id# order by id limit 1

但出现了错误提示“Incorrect usage of UNION and ORDER BY”。看来不能这么用union和order by,但这里确实是需要order by的。很快,我想到了一个变通的写法:

select * from (
select id,title from subjects where id>#some_id# order by id limit 1
) union
select id,title from subjects where id<#some_id# order by id limit 1

从经验上说,第二个子句该不会被union影响,可以用order by。于是把第一个子句包在一个括号里,这下应该就可以了。可是还是有错误,提示“ Every derived table must have its own alias”。这里的提示是需要给我们括号里面生成的临时表取一个别名,这个好办多了。于是改为:

select * from (
select id,title from subjects where id>#some_id# order by id limit 1
) as t1 union
select id,title from subjects where id<#some_id# order by id limit 1

这条语句成功执行并且得到了正确的结果,在此写下来备忘。

更多关于MySQL相关内容感兴趣的读者可查看本站专题:《MySQL日志操作技巧大全》、《MySQL事务操作技巧汇总》、《MySQL存储过程技巧大全》、《MySQL数据库锁相关技巧汇总》及《MySQL常用函数大汇总》

希望本文所述对大家MySQL数据库计有所帮助。

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 分享下mysql各个主要版本之间的差异
  • MySQL essential版本和普通版本有什么区别?
  • redhat 5.4下安装MYSQL全过程
  • 如何用SQL命令查看Mysql数据库大小
  • 解析mysql中如何获得数据库的大小
  • 解析mysql修改为utf8后仍然有乱码的问题
  • 5个常用的MySQL数据库管理工具详细介绍
  • 解析在MySQL里创建外键时ERROR 1005的解决办法
  • 解析远程连接管理其他机器上的MYSQL数据库
  • mysql 精简过程(删除一些文件)

相关文章

  • 2018-12-05MSSQL汉字转拼音函数实现语句
  • 2018-12-05MongoDB中帐号管理(用户名密码设置)
  • 2018-12-05sql 查询慢的原因分析
  • 2018-12-05在Oracle 8x实现自动断开后再连接
  • 2018-12-05MySQL教程--通过配置文件连接数据库操作详解
  • 2018-12-05数据库 日期加减处理
  • 2017-05-11mysql优化连接数防止访问量过高的方法
  • 2017-09-02MySQL分布式集群之MyCAT的配置文件schema.xml详解
  • 2018-12-05sql 存储过程分页代码 支持亿万庞大数据量
  • 2018-12-05C# 操作PostgreSQL 数据库

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • MYSQL explain 执行计划
    • mysql 配置参数详解
    • SqlServer2005 数据库同步配置图文详解
    • MySQL判断字符串是否是数字
    • Sqlserver2000 数据库备份实例代码
    • 给Oracle添加split和splitstr函数的方法
    • 用户"sa"登陆失败 SQLServer 错误18456的解决方法
    • 在安装了Sql2000的基础上安装Sql2005的详细过程 图文
    • MsSql中SQL 获取所有上级的实例代码
    • 分享csv导入数据到mysql实例

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有