使用Index提示 强制使用索引
2013-03-28 21:33
295 查看
使用Index提示 强制使用索引
Index Hints的格式如下:虽然索引并不总会快于全表扫描,但是很多时候我们希望Oracle使用索引来执行某些SQL,这时候我们可以通过index hints来强制SQL使用index.
/*+ INDEX ( table [index [index]...] ) */
我们简单看一下这个提示的用法(范例为Oracle10g数据库):
SQL> create table t as select username,password from dba_users;
Table created.
SQL> create index i_t on t(username);
Index created.
SQL> set autotrace trace explain
SQL> select /*+ index(t i_t) */ * from t where username='EYGLE';
Execution Plan ---------------------------------------------------------- Plan hash value: 2928007915
------------------------------------------------------------------------------------ | Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time | ------------------------------------------------------------------------------------ | 0 | SELECT STATEMENT | | 1 | 34 | 2 (0)| 00:00:01 | | 1 | TABLE ACCESS BY INDEX ROWID| T | 1 | 34 | 2 (0)| 00:00:01 | |* 2 | INDEX RANGE SCAN | I_T | 1 | | 1 (0)| 00:00:01 | ------------------------------------------------------------------------------------
Predicate Information (identified by operation id): ---------------------------------------------------
2 - access("USERNAME"='EYGLE')
Note ----- - dynamic sampling used for this statement
这里的查询使用了索引.
需要注意的是使用CTAS方式创建数据表,新建表会继承原表的约束属性:
SQL> desc t Name Null? Type ----------------------------------------- -------- ---------------------------- USERNAME NOT NULL VARCHAR2(30) PASSWORD VARCHAR2(30)
如果不使用Hints,此处Oracle不会使用索引:
SQL> select * from t where username='EYGLE';
Execution Plan ---------------------------------------------------------- Plan hash value: 1601196873
-------------------------------------------------------------------------- | Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time | -------------------------------------------------------------------------- | 0 | SELECT STATEMENT | | 1 | 34 | 2 (0)| 00:00:01 | |* 1 | TABLE ACCESS FULL| T | 1 | 34 | 2 (0)| 00:00:01 | --------------------------------------------------------------------------
Predicate Information (identified by operation id): ---------------------------------------------------
1 - filter("USERNAME"='EYGLE')
Note ----- - dynamic sampling used for this statement
索引和全表扫描的选择和取舍并非简单,本文不作进一步探讨.
相关文章推荐
- 使用Index提示 强制使用索引
- Oracle技术之使用Index提示强制使用索引
- force index(idx_name) 强制使用索引用法小结
- DB:实战 Force Index() 强制 MariaDB使用索引解决慢查询问题
- DB:实战 Force Index() 强制 MariaDB使用索引解决慢查询问题
- mysql force Index 查询强制使用索引
- MSSQL强制使用index
- 【转】mysql force Index 强制索引
- mysql强制使用索引与不使用索引
- Oracle hint方式强制使用索引
- MySQL之 SQL force Index 强制索引
- oracle like 上强制使用索引
- JsRender for index 循环索引使用说明
- MYSQL强制使用索引和禁止使用索引
- 解决“提示错误: 无法对 表或索引视图'T_shili' 使用 CONTAINS 或 FREETEXT 谓词,因为它未编制全文索引。 ”
- 8.2.1.7 Use of Index Extensions 使用索引扩展
- 学习问题:使用MATLAB工具箱进行双目标定,提示索引超出矩阵范围。
- odi接口抽取数据报错提示Create Unique Index on flow table创建唯一索引失败解决方法
- 在SQL语句中使用索引提示提高SQL性能
- MYSQL强制使用索引和禁止使用索引