在优化SQL语句中使用虚拟索引
来源:互联网 发布:windows核心编程下载 编辑:程序博客网 时间:2024/06/14 19:40
定义:虚拟索引(virtual index) 是指没有创建对应的物理段的索引。
虚拟索引的目的:是在不损耗主机CPU,IO,磁盘空间去实际创建索引的情况下,来判断一个索引是否能够对SQL优化起到作用。列如我们在优化一条SQL语句的时候,通常会查看需要优化的语句的执行计划,在考虑是否需要在表的某列上建立索引时就可以用到虚拟索引。虚拟索引建立的时候因为其没有消耗主机的相关资源,因此可以在相当快的时间内建立完成。
下面我们来看一下试验:
首先建立两张测试表
create table bigtab as select rownum as id,a.* from sys.all_objects a;
create table smalltab as select rownum as id,a.* from sys.all_tables a;
多次运行以下语句,以插入多一些测试数据:
insert into bigtab select ronum as id,a.* from sys.all_objects a;
insert into smalltab select rownum as id,a.* from sys.all_tables a;
查看需要执行语句的执行计划:
SQL> explain plan for select count(*) from bigtab a,smalltab b where a.object_name=b.table_name;Explained.SQL> select * from table(dbms_xplan.display());PLAN_TABLE_OUTPUT--------------------------------------------------------------------------------Plan hash value: 3089226980--------------------------------------------------------------------------------| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |--------------------------------------------------------------------------------| 0 | SELECT STATEMENT | | 1 | 40 | 518 (1)| 00:00:07 || 1 | SORT AGGREGATE | | 1 | 40 | | ||* 2 | HASH JOIN | | 99838 | 3899K| 518 (1)| 00:00:07 || 3 | TABLE ACCESS FULL| SMALLTAB | 15311 | 299K| 172 (0)| 00:00:03 || 4 | TABLE ACCESS FULL| BIGTAB | 85284 | 1665K| 345 (1)| 00:00:05 |--------------------------------------------------------------------------------PLAN_TABLE_OUTPUT--------------------------------------------------------------------------------Predicate Information (identified by operation id):--------------------------------------------------- 2 - access("A"."OBJECT_NAME"="B"."TABLE_NAME")16 rows selected.
下面我们在两个表上创建两个虚拟索引,分别在object_name和table_name列上,看看优化器是否会使用这两个索引,以及优化器的成本会如何变化。
SQL> show parameter _use_nosegmentSQL> alter session set "_use_nosegment_indexes"=true;Session altered.SQL> show parameter _use_nosegment NAME TYPE VALUE------------------------------------ ----------- ------------------------------_use_nosegment_indexes boolean TRUESQL> create index big_ind on bigtab(object_name) nosegment;Index created.SQL> create index small_ind on smalltab(table_name) nosegment;
create index语句的NOSEGMENT选项表明这个索引是“虚拟的”-----就是没有与之相关联的实际索引段。如果优化器认为这个索引有用,参数_use_nosegment_indexes将指示数据库可以在执行计划中使用这些索引。下面我们来看看如果真的创建这些索引,它们是否值得使用:
SQL> explain plan for select count(*) from bigtab a,smalltab b where a.object_name=b.table_name;Explained.SQL> select * from table(dbms_xplan.display()); PLAN_TABLE_OUTPUT--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------Plan hash value: 1254475829------------------------------------------------------------------------------------| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |------------------------------------------------------------------------------------| 0 | SELECT STATEMENT | | 1 | 40 | 19 (6)| 00:00:01 || 1 | SORT AGGREGATE | | 1 | 40 | | ||* 2 | HASH JOIN | | 99838 | 3899K| 19 (6)| 00:00:01 || 3 | INDEX FAST FULL SCAN| SMALL_IND | 15311 | 299K| 9 (0)| 00:00:01 || 4 | INDEX FAST FULL SCAN| BIG_IND | 85284 | 1665K| 9 (0)| 00:00:01 |------------------------------------------------------------------------------------PLAN_TABLE_OUTPUT--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------Predicate Information (identified by operation id):--------------------------------------------------- 2 - access("A"."OBJECT_NAME"="B"."TABLE_NAME")16 rows selected.
执行计划显示,这两个索引确实被认为有用,优化器估算的成本也下降到19了。所以如果需要优化语句可以建议创建这些索引。
- 在优化SQL语句中使用虚拟索引
- 在SQL语句中使用索引提示提高SQL性能
- SQL语句优化与索引的使用
- 在SQL Server中使用索引的技巧及sql索引优化策略
- SQL 语句索引优化查询
- sql语句优化之索引
- SQL语句优化-重点在于使用到索引
- sql优化-使用索引
- SQL语句优化过程中,使用Hint
- SQL优化-索引 (六)改善SQL语句
- 在 Access 中使用 SQL 建索引
- 在ABAP的SQL语句中关联SAP表索引
- 分析sql语句中索引是否被使用
- 基于索引的SQL语句优化
- 基于索引的SQL语句优化
- 基于索引的SQL语句优化之一
- 在ASP中使用SQL语句
- 在SQL语句中“?”参数的使用
- Linux应用开发---Linux下浮点数与字符串转换
- 退出当前shell
- C语言栈帧
- 《计算机视觉》总结2
- 高手分享:善用组策略禁止不明U盘使用_xitongshoucang.com
- 在优化SQL语句中使用虚拟索引
- c#读取写入文本文件
- C库函数标准编程之fscanf()函数解读及其实验
- SSL协议与数字证书原理
- 八大排序算法总结
- FORM中使用onSubmit="return false"防止表单自动提交,以及submit和button提交表单的区别
- AATCC 美国纺织化学师与印染师协会标准
- 启动 Eclipse 弹出“Failed to load the JNI shared library jvm.dll”错误的解决方法!
- 使用命令查看spfile<sid>.ora中的内容