80152 2017-04-19 15:17
浏览 614
已结题

ORACLE 索引查询SQL优化

有一样表test 建表语句如下所示,该表数据量10亿,有这一样条sql,

select * from test where (key1>? or(key1=? and key2>?) or (key1=? and key2=? and key3>?)) and (key1<? or(key1=? and key2<?) or (key1=? and key2=? and key3<?)) order by key1 asc,key2 asc,key3 asc;

这条sql 改怎么优化,test表的主键是b树索引。mysql 支持row comparisons 语法

支持这种形式(key1,key2,key3) > (?,?,?) and (key1,key2,key3)<=(?,?,?),那么oracle该怎么优化呢?求大牛指点

create table test
(
key1 int,
key2 int,
key3 int,
value int,
primary key(key1,key2,key3)
)

  • 写回答

0条回答

    报告相同问题?

    悬赏问题

    • ¥15 对于相关问题的求解与代码
    • ¥15 ubuntu子系统密码忘记
    • ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
    • ¥15 保护模式-系统加载-段寄存器
    • ¥15 电脑桌面设定一个区域禁止鼠标操作
    • ¥15 求NPF226060磁芯的详细资料
    • ¥15 使用R语言marginaleffects包进行边际效应图绘制
    • ¥20 usb设备兼容性问题
    • ¥15 错误(10048): “调用exui内部功能”库命令的参数“参数4”不能接受空数据。怎么解决啊
    • ¥15 安装svn网络有问题怎么办