源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

Oracle使用强制索引的方法与注意事项

  • 时间:2021-12-18 17:40 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:Oracle使用强制索引的方法与注意事项
[b]Oracle使用强制索引[/b] 在一些场景下,可能ORACLE不会自动走索引,这时候,如果对业务清晰,可以尝试使用强制索引,测试查询语句的性能。 以EMP表为例: 先在EMP表中建立唯一索引,如图。 [img]http://files.jb51.net/file_images/article/201711/2017116184236444.png?2017106184310[/img] [b]普通搜索:[/b]
SELECT * FROM EMP T
查看执行计划: [img]http://files.jb51.net/file_images/article/201711/2017116184338434.png?2017106184347[/img] 可以看到,是走的全表扫描。 [b]使用强制索引,在SELECT 后面加上/*.......*/ 中间加上索引的属性,代码如下:[/b]
SELECT /*+index(t pk_emp)*/* FROM EMP T 

--强制索引,/*.....*/第一个星星后不能有空格,里边内容结构为:加号index(表名 空格 索引名)。
--如果表用了别名,注释里的表也要使用别名。
[img]http://files.jb51.net/file_images/article/201711/2017116184457805.png?201710618455[/img]   可以看到,这是走的是索引PK_EMP。 [b]Oracle使用强制索引注意事项[/b] 最近对Oracle的SQL索引生效条件进行了验证,发现如下规律,记录如下: [b]1、索引生效与记录的条数相关[/b]       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' 
); 
[b]2、T_MAINS已根据某个时间类型的字段进行分区,查询条件中如果能够精准定位到某个分区,可以提高SQL的执行效率[/b] [b]总结[/b] 以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对编程素材网的支持。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部