您好,欢迎访问一九零五行业门户网

在优化SQL语句中使用虚拟索引

是在不损耗主机cpu,io,磁盘空间去实际创建索引的情况下,来判断一个索引是否能够对sql优化起到作用。列如我们在优化一条sql语句的
定义:虚拟索引(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_nosegment
sql> alter session set _use_nosegment_indexes=true;
session altered.
sql> show parameter _use_nosegment                 
name                                type        value
------------------------------------ ----------- ------------------------------
_use_nosegment_indexes              boolean    true
sql> create index big_ind on bigtab(object_name) nosegment;
index created.
sql> create index small_ind on smalltab(table_name) nosegment;
其它类似信息

推荐信息