sxwnhywk 2015-10-09 03:03 采纳率: 50%
浏览 2746
已采纳

oracle数据库select效率

前提:数据库有将近100W条数据。
目的:需要排序后获取前10条。
处理:select * from (select * from table where col1=1 order by col1) where rownum <= 10;
问题:如上的sql语句,如果数据少的话,可以达到要求;但是如果数据量将近100W,效率就不行了。因为为括号里面的sql是提取全部数据,然后对所有数据就行排序,然后才取前10条。效率可想而知。
各位大虾有没有什么高招,可以提高下oracle的select的效率。

  • 写回答

3条回答

  • WorldMobile 2015-10-10 00:54
    关注

    select * from (select * from table where col1=1 order by col1) where rownum <= 10;

    如果这条语句的话,你可以根据col1建立一个索引,速度就上去了

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 如何在scanpy上做差异基因和通路富集?
  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?
  • ¥15 c++头文件不能识别CDialog