• 企业400电话
  • 网络优化推广
  • AI电话机器人
  • 呼叫中心
  • 全 部 栏 目

    网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    Oracle使用强制索引的方法与注意事项
    POST TIME:2021-10-18 21:49

    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 
     * 
    FROM 
     T_MAINS 
    WHERE 
     date > TO_DATE (--备注今天是2017-01-23 
      '2016-01-01', 
      'yyyy-mm-dd hh24:mi:ss' 
     ) 
    AND date  TO_DATE ( 
     '2016-11-30', 
     'yyyy-mm-dd hh24:mi:ss' 
    ); 

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

    总结

    以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。

    您可能感兴趣的文章:
    • Oracle数据库中建立索引的基本方法讲解
    • Oracle轻松取得建表和索引的DDL语句
    • Oracle中如何把表和索引放在不同的表空间里
    • oracle索引介绍(图文详解)
    • Oracle关于重建索引争论的总结
    • Oracle索引(B*tree与Bitmap)的学习总结
    • Oracle 如何创建和使用全文索引
    • oracle 索引不能使用深入解析
    • Oracle Index索引无效的原因与解决方法
    • oracle索引的测试实例代码
    上一篇:Oracle dbca时报:ORA-12547: TNS:lost contact错误的解决
    下一篇:Oracle 11g用户修改密码及加锁解锁功能实例代码
  • 相关文章
  • 

    关于我们 | 付款方式 | 荣誉资质 | 业务提交 | 代理合作


    © 2016-2020 巨人网络通讯

    时间:9:00-21:00 (节假日不休)

    地址:江苏信息产业基地11号楼四层

    《增值电信业务经营许可证》 苏B2-20120278

    X

    截屏,微信识别二维码

    微信号:veteran88

    (点击微信号复制,添加好友)

     打开微信