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 使用C#,asp.net读取Excel文件并保存到Oracle数据库
    • ¥15 C# datagridview 单元格显示进度及值
    • ¥15 thinkphp6配合social login单点登录问题
    • ¥15 HFSS 中的 H 场图与 MATLAB 中绘制的 B1 场 部分对应不上
    • ¥15 如何在scanpy上做差异基因和通路富集?
    • ¥20 关于#硬件工程#的问题,请各位专家解答!
    • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
    • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
    • ¥30 虚心请教几个问题,小生先有礼了
    • ¥30 截图中的mathematics程序转换成matlab