Oracle 12CR2查询转换教程之表扩展详解查询转换教程之表扩展详解
Oracle 12cR2版本已经发布有一段时间,下面这篇文章主要给大家介绍了关于Oracle 12CR2查询转换教程之表扩展的相关资料,文中
通过示例代码介绍的非常详细,需要的朋友可以参考借鉴,下面随着小编来一起学习学习吧
前言前言
在表扩展中,对于读取一个分区表部分数据时优化器会生成使用索引的执行计划。基于索引执行计划可以提高性能,但索引维护会增加开锁。在许多数
据库中,DML只影响小部分数据。对于频繁更新的表表扩展使用基于索引的执行计划。你可以在以读取为主的数据上创建一个索引,在以频繁变化的数
据上消除索引开销。通过这种方式,表扩展在避免索引维护的同时提高了性能。
下面话不多说了,来一起看看详细的介绍吧
表扩展工作原理表扩展工作原理
表分区使用表扩展成为可能。如果在一个分区表上创建一个本地索引,那么优化器可能会标记索引对于特定的分区不可使用。实际有些分区没有创建索
引。在表扩展中,优化器将查询转换为一个union all语句,让一些子查询访问创建索引的分区,一些子查询访问没有创建索引的分区。优化器可以为每个
分区选择最有效的访问路径,而不管它是否存在于查询所要访问的所有分区中。
优化器不总是会选择表扩展优化器不总是会选择表扩展
.表扩展是基于成本
当数据库访问扩展表的每个分区只会跨越union all的所有分支一次,数据库所连接的任何表都是在分支中被访问。
.语义问题可能导致表扩展无效
例如,一个表出现在一个外连接的右边对于表扩展来说是无效的。
可以使用expand_table hint来控制表扩展。这个hint会覆盖基于成本的决策,但不会覆盖语义检查。
表扩展使用场景表扩展使用场景
优化器基于查询中出现的谓词条件对每个表必须被访问的分区保持跟踪。分区裁剪能让优化器使用表扩展来生成更有效的执行计划。
下面的例子假设满足以下条件:
.想要对sh.sales表执行星型查询,表sh.sales是基于time_id列进行范围分区的一个分区表。
.想要禁用特定分区上的索引来查看表扩展的优点。
操作步骤如下:
1.以sh用户登录数据库
[oracle@jytest1 ~]$ sqlplus sh/*****@jypdb
SQL*Plus: Release 12.2.0.1.0 Production on Wed Oct 31 18:09:54 2018
Copyright (c) 1982, 2016, Oracle. All rights reserved.
Last Successful login time: Wed Oct 24 2018 17:00:11 +08:00
Connected to:
Oracle Database 12c Enterprise Edition Release 12.2.0.1.0 - 64bit Production
SQL>
2.执行以下查询
SQL> select * from sales where time_id >= to_date('2000-01-01 00:00:00', 'syyyy-mm-dd hh24:mi:ss') and prod_id = 38;
...........
38 2470 24-DEC-01 2 999 1 31.47
38 13440 24-DEC-01 2 999 1 31.47
38 490 28-DEC-01 2 999 1 31.47
38 8406 28-DEC-01 2 999 1 31.47
38 1466 31-DEC-01 3 351 1 31.47
38 4340 31-DEC-01 3 351 1 31.47
38 10658 31-DEC-01 3 351 1 31.47
38 11390 31-DEC-01 3 351 1 31.47
38 23226 31-DEC-01 3 351 1 31.47
4224 rows selected.
3.查询执行计划
SQL> select * from table(dbms_xplan.display_cursor(null,null,'advanced allstats last runstats_last peeked_binds'));
SQL_ID 214qgysqqz0k8, child number 0
-------------------------------------
select * from sales where time_id >= to_date('2000-01-01 00:00:00',
'syyyy-mm-dd hh24:mi:ss') and prod_id = 38
Plan hash value: 2342444420
-----------------------------------------------------------------------------------------------------------------------------------------------------------------------
| Id | Operation | Name | Starts | E-Rows |E-Bytes| Cost (%CPU)| E-Time | Pstart| Pstop | A-Rows | A-Time | Buffers |
-----------------------------------------------------------------------------------------------------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | 1 | | | 224 (100)| | | | 4224 |00:00:00.03 | 334 |
| 1 | PARTITION RANGE ITERATOR | | 1 | 5078 | 143K| 224 (0)| 00:00:01 | 13 | 28 | 4224 |00:00:00.03 | 334 |
| 2 | TABLE ACCESS BY LOCAL INDEX ROWID BATCHED| SALES | 16 | 5078 | 143K| 224 (0)| 00:00:01 | 13 | 28 | 4224 |00:00:00.02 | 334 |
| 3 | BITMAP CONVERSION TO ROWIDS | | 8 | | | | | | | 4224 |00:00:00.01 | 24 |