前提:数据库有将近100W条数据。
目的:需要排序后获取前10条。
处理:select * from (select * from table where col1=1 order by col1) where rownum <= 10;
问题:如上的sql语句,如果数据少的话,可以达到要求;但是如果数据量将近100W,效率就不行了。因为为括号里面的sql是提取全部数据,然后对所有数据就行排序,然后才取前10条。效率可想而知。
各位大虾有没有什么高招,可以提高下oracle的select的效率。
oracle数据库select效率
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
3条回答 默认 最新
- WorldMobile 2015-10-10 00:54关注
select * from (select * from table where col1=1 order by col1) where rownum <= 10;
如果这条语句的话,你可以根据col1建立一个索引,速度就上去了
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 求差集那个函数有问题,有无佬可以解决
- ¥15 【提问】基于Invest的水源涵养
- ¥20 微信网友居然可以通过vx号找到我绑的手机号
- ¥15 寻一个支付宝扫码远程授权登录的软件助手app
- ¥15 解riccati方程组
- ¥15 display:none;样式在嵌套结构中的已设置了display样式的元素上不起作用?
- ¥15 使用rabbitMQ 消息队列作为url源进行多线程爬取时,总有几个url没有处理的问题。
- ¥15 Ubuntu在安装序列比对软件STAR时出现报错如何解决
- ¥50 树莓派安卓APK系统签名
- ¥65 汇编语言除法溢出问题