ORA-00979不是GROUP BY表达式

问题

对于常见在select中出现的列没有全部出现在group by的后面这种原因就不再进行细说了,现说下我碰到的比较特殊的情况。在Oracle的11.2.0.1.0版本上执行下面语句报ORA-00979不是GROUP BY表达式错误

select substr(a.empno,1,4) as year,count(1) 
from (select * from  scott.emp) a 
group by substr(a.empno,1,4) 
order by substr(a.empno,1,4) desc;

但是换成下面两种方式就没用问题:

方式1 不使用子查询
select substr(a.empno,1,4) as year,count(1) 
from scott.emp a 
group by substr(a.empno,1,4) 
order by substr(a.empno,1,4) desc;
方式2 order by 中使用别名
select substr(a.empno,1,4) as year,count(1) 
from (select * from  scott.emp) a 
group by substr(a.empno,1,4) 
order by year desc;

总结

个人分析,是因为Oracle的11.2.0.1.0版本不支持:在使用子查询且有group by 的情况下,对order by里的字段不使用别名。所以以后在写sql的时候尽量规范化,即order by 后面尽量使用别名。注:本人使用11.2.0.4.0版本时,并未碰到上面的问题,故推测是11.2.0.1.0版本问题,可通过升级oracle版本进行测试。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值