最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

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

来源:动视网 责编:小OO 时间:2020-11-09 08:45:08
文档

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

Oracle使用强制索引。在一些场景下,可能ORACLE不会自动走索引,这时候,如果对业务清晰,可以尝试使用强制索引,测试查询语句的性能。以EMP表为例。先在EMP表中建立唯一索引,如图。普通搜索。SELECT * FROM EMP T。查看执行计划。可以看到,是走的全表扫描。使用强制索引,在SELECT 后面加上/*.......*/ 中间加上索引的属性,代码如下:SELECT /*+index(t pk_emp)*/* FROM EMP T --强制索引,/*.....*/第一个星星后不能有空格,里边内容结构为:加号index(表名 空格 索引名)。--如果表用了别名,注释里的表也要使用别名。可以看到,这是走的是索引PK_EMP。
推荐度:
导读Oracle使用强制索引。在一些场景下,可能ORACLE不会自动走索引,这时候,如果对业务清晰,可以尝试使用强制索引,测试查询语句的性能。以EMP表为例。先在EMP表中建立唯一索引,如图。普通搜索。SELECT * FROM EMP T。查看执行计划。可以看到,是走的全表扫描。使用强制索引,在SELECT 后面加上/*.......*/ 中间加上索引的属性,代码如下:SELECT /*+index(t pk_emp)*/* FROM EMP T --强制索引,/*.....*/第一个星星后不能有空格,里边内容结构为:加号index(表名 空格 索引名)。--如果表用了别名,注释里的表也要使用别名。可以看到,这是走的是索引PK_EMP。
 本文主要给大家介绍了关于Oracle使用强制索引的方法与注意事项,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。希望能帮助到大家。

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使用强制索引。在一些场景下,可能ORACLE不会自动走索引,这时候,如果对业务清晰,可以尝试使用强制索引,测试查询语句的性能。以EMP表为例。先在EMP表中建立唯一索引,如图。普通搜索。SELECT * FROM EMP T。查看执行计划。可以看到,是走的全表扫描。使用强制索引,在SELECT 后面加上/*.......*/ 中间加上索引的属性,代码如下:SELECT /*+index(t pk_emp)*/* FROM EMP T --强制索引,/*.....*/第一个星星后不能有空格,里边内容结构为:加号index(表名 空格 索引名)。--如果表用了别名,注释里的表也要使用别名。可以看到,这是走的是索引PK_EMP。
推荐度:
标签: 强制 使用 oracle
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top