基于CBO优化器的环境中,SQL执行计划的生成依赖于统计信息的真实与完整。如列的离散度,列上的直方图,索引的可用性,索引上的聚簇因子。当这些信息是真实完整的情况下,CBO优化器通常都可以制定最优的执行计划。也正因此CBO优化器也灵活,难以控制,任一信息的不真实或缺失都可能导致执行计划发生变化而产生多个版本。经常碰到的情形是之前的某个SQL语句前阵子还不是TOP SQL,而最近变成了TOP SQL。或者说之前尽管是TOP SQL但,但最近尽然成了TOP 1。对于此情形,我们可以比对SQL语句的历史执行计划进行分析是何种原因导致SQL变慢或执行计划发生变化。下面通过例子来模拟SQL执行计划变异的情形。
1、创建演示环境--演示环境
scott@SYBO2SZ> select * from v$version where rownum<2;BANNER
----------------------------------------------------------------
Oracle Database 10g Release 10.2.0.3.0 - 64bit Production--创建1000000万记录的表
scott@SYBO2SZ> @cr_big_tbcheck total rows for big_table
====================================
COUNT(*)
----------
1000000--为表创建索引
scott@SYBO2SZ> create index i_big_tb_owner on big_table(owner);sys@SYBO2SZ> conn / as sysdba;sys@SYBO2SZ> select snap_id from dba_hist_snapshot order by snap_id; SNAP_ID
----------
30
31--清除awr的历史记录,shared pool及buffer cache
sys@SYBO2SZ> exec dbms_workload_repository.drop_snapshot_range(30,31);sys@SYBO2SZ> alter system flush shared_pool;sys@SYBO2SZ> alter system flush buffer_cache;--清除dba_hist_sql_plan视图,实际上清除wrh$_sql_plan,wrh$_sqltext,wrh$_sqlstat
sys@SYBO2SZ> truncate table wrh$_sql_plan;--清除dba_hist_sql_sqltext以及dba_hist_sqlstat视图sys@SYBO2SZ> truncate table wrh$_sqltext;sys@SYBO2SZ> truncate table wrh$_sqlstat;sys@SYBO2SZ> select count(*) from dba_hist_sql_plan; COUNT(*)
----------
0sys@SYBO2SZ> select count(*) from dba_hist_sqltext; COUNT(*)
----------
0
MySQL数据库id重复无法删除的解决方法使用优化器性能视图获取SQL语句执行环境相关资讯 Oracle SQL语句 Oracle SQL执行计划
- Oracle手动固定SQL执行计划 (04月16日)
- 最权威Oracle获取SQL语句执行计划 (05/07/2015 19:22:48)
- Oracle SQL 执行计划和分析小结 (06/04/2014 19:46:58)
| - Oracle SQL语句追踪 (05/09/2015 09:42:25)
- Oracle执行SQL查询语句的步骤 (09/26/2014 19:40:59)
- Oracle数据库SQL语句的执行过程 (10/12/2013 17:37:20)
|
本文评论 查看全部评论 (0)