在子查询中使用 order by 总是告错:ORA-00907: missing right parenth.解决办法!

在子查询中使用 order by 总是告错.谁知道解决办法?
oracle   8.0版本,在子查询中使用   order   by   总是告错. 
例如需要从学生信息表中提取分数列前5名的学生的姓名和成绩,使用以下语句: 

Select   name,   score   From   
    (Select   name,   score   From   studentInfo   Order   By   score) 
Where   (rowNum   <   6)   
Order   By   rowNum 

执行时报告错误:ORA-00907:missing   right   parenthesis 
而如果把子查询中的   Order   By   score   去掉,则运行正常,但显然不是所要的结果. 
在几台机器上执行都有上述问题. 

是oracle   的版本问题吗?但业主只能用这个版本,有其他替代的语句吗? 




------解决方案--------------------
Select name, score From 
(Select name, score From studentInfo Order By score) t 
Where (rowNum < 6) 
Order By rowNum 

------解决方案--------------------
--同等语句 

Select name, score from studentInfo a 
Where (Select count(*) from studentInfo where a.Score> Score) <5 
------解决方案--------------------
oracle8不支持order by 嵌套字查詢的. 
可以用臨時表的辦法解決. 
create table tmp as Select name, score From studentInfo Order By score 
select name, score From tmp where rowNum <6 Order By rowNum 
drop table tmp 
------解决方案--------------------
Select name, score From 
(Select name, score From studentInfo Order By score desc) 
Where rowNum < 6 
这样不行?
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值