前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >union all 和 order by 连用的问题

union all 和 order by 连用的问题

作者头像
IT云清
发布2019-01-22 10:37:50
3.6K0
发布2019-01-22 10:37:50
举报
文章被收录于专栏:IT云清

在mybatis中,如果union 或者union all 和 order by连用,会发现运行会报错:

代码语言:javascript
复制
com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: Unknown column 'a' in 'order clause'

这里的字段a是无法识别的。这里写一段伪代码如下:

代码语言:javascript
复制
select a,b,c
from table_1
where d = 5

union 

select a,b,c
from table_1
where e = 8

order by a desc

尽管两个select出的结果列名都是a,b,c,但是最后排序时按照字段a排序,发现报错:说无法识别a字段。

处理办法:上面的排序那一句改为:

代码语言:javascript
复制
order by 1 desc

用你需要的字段的位置索引来定位这个字段,就可以解决了。

这个问题存在于mybatis中,但是直接在数据库中执行时没有问题的。具体原因还不清楚。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2018年01月26日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档