• ADADADADAD

    关于Oracle使用强制索引的方法及其注意事项[ mysql数据库 ]

    mysql数据库 时间:2024-12-25 09:58:07

    作者:文/会员上传

    简介:

    Oracle使用强制索引在一些场景下,可能ORACLE不会自动走索引,这时候,如果对业务清晰,可以尝试使用强制索引,测试查询语句的性能。以EMP表为例:先在EMP表中建立唯一索引,如图。普通搜

    以下为本文的正文内容,内容仅供参考!本站为公益性网站,复制本文以及下载DOC文档全部免费。

    Oracle使用强制索引

    在一些场景下,可能ORACLE不会自动走索引,这时候,如果对业务清晰,可以尝试使用强制索引,测试查询语句的性能。

    以EMP表为例:

    先在EMP表中建立唯一索引,如图。

    普通搜索:

    SELECT * FROM EMP T

    查看执行计划:

    可以看到,是走的全表扫描。

    使用强制索引,在SELECT 后面加上/*.......*/ 中间加上索引的属性,代码如下:

    SELECT /*+index(t pk_emp)*/* FROM EMP T --强制索引,/*.....*/第一个星星后不能有空格,里边内容结构为:加号index(表名 空格 索引名)。--如果表用了别名,注释里的表也要使用别名。

    可以看到,这是走的是索引PK_EMP。

    Oracle使用强制索引注意事项

    最近对Oracle的SQL索引生效条件进行了验证,发现如下规律,记录如下:

    1、索引生效与记录的条数相关

    a、2016-01-01~2016-11-30 数据量402518,索引生效

    b、2016-01-01~2016-12-30 数据量444844,索引不生效

    SELECT* FROMT_MAINS WHEREdate > TO_DATE (--备注今天是2017-01-23 '2016-01-01', 'yyyy-mm-dd hh34:mi:ss') AND date < TO_DATE ('2016-11-30','yyyy-mm-dd hh34:mi:ss' );

    2、T_MAINS已根据某个时间类型的字段进行分区,查询条件中如果能够精准定位到某个分区,可以提高SQL的执行效率

    关于Oracle使用强制索引的方法及其注意事项.docx

    将本文的Word文档下载到电脑

    推荐度:

    下载
    热门标签: oracle索引强制