请教个关于sql优化的问题。order+表达式。
时间:2010-08-18
来源:互联网
select a,b,c from (select a,b ,c,row_number()over( order by (b/a)*1.314 desc) rn from test) where rn<1000
目的就是想去 test表里面的(b/a)*1.314最大的1000列。
由于order by 里面带表达式,导致查询效率极低。有没有什么办法可以优化下。谢谢。
目的就是想去 test表里面的(b/a)*1.314最大的1000列。
由于order by 里面带表达式,导致查询效率极低。有没有什么办法可以优化下。谢谢。
作者: toniz 发布时间: 2010-08-18
感觉没有啊。太难了。
作者: renxiao2003 发布时间: 2010-08-18

相同数据。上面这个语句,oracle整整用了642秒,而Greenplum仅仅用了11秒。。。。。
这个差距我看了相同无语。
而我发现仅仅做计算并不需要多少时间,主要是一ORDER,就惨了。那效率。。。。。。
作者: toniz 发布时间: 2010-08-18
相关阅读 更多
热门阅读
-
office 2019专业增强版最新2021版激活秘钥/序列号/激活码推荐 附激活工具
阅读:74
-
如何安装mysql8.0
阅读:31
-
Word快速设置标题样式步骤详解
阅读:28
-
20+道必知必会的Vue面试题(附答案解析)
阅读:37
-
HTML如何制作表单
阅读:22
-
百词斩可以改天数吗?当然可以,4个步骤轻松修改天数!
阅读:31
-
ET文件格式和XLS格式文件之间如何转化?
阅读:24
-
react和vue的区别及优缺点是什么
阅读:121
-
支付宝人脸识别如何关闭?
阅读:21
-
腾讯微云怎么修改照片或视频备份路径?
阅读:28