[20201105]再分析sql語句.txt
[20201105]再分析sql語句.txt
--//有時候工作需要再分析執行某個sql語句,一般常用的方法就是從共享池裡面清除,重新整理共享池,但是這樣做代價太大。
--//還有一種方式使用 dbms_shared_pool.purge命令。我使用的指令碼如下:
$ cat flush_sql.sql
DECLARE
name varchar2(100);
version varchar2(3);
BEGIN
select regexp_replace(version,'\..*') into version from v$instance;
if version = '10' then
execute immediate
q'[alter session set events '5614566 trace name context forever']'; -- bug fix for 10.2.0.4 backport
end if;
select address||','||hash_value into name from v$sqlarea where sql_id like '&1';
dbms_shared_pool.purge(name,'C',&2);
END;
/
--//當然還有一些簡單的方法就是grant或者comment註解表資訊,這樣可以導致執行時重新分析。
--//前一段時間看連結:
https://martincarstenbach.wordpress.com/2020/10/26/enforcing-a-re-parse-of-a-cursor-in-autonomous-database-using-a-hammer/
--//作者提供了另外的方法,設定表noparallel,實際上根本沒有改動,導致再次執行時重新分析。自己測試看看:
1.環境:
SCOTT@book> @ ver1
PORT_STRING VERSION BANNER
------------------------------ -------------- --------------------------------------------------------------------------------
x86_64/Linux 2.4.xx 11.2.0.4.0 Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production
2.測試:
SCOTT@book> select count(*) from dept ;
COUNT(*)
----------
4
SCOTT@book> @ hash
HASH_VALUE SQL_ID CHILD_NUMBER HASH_HEX
---------- ------------- ------------ ---------
3940382763 dh11gtgpduy1b 0 eadd782b
SCOTT@book> select plan_hash_value, child_number, invalidations, executions, is_bind_aware, is_bind_sensitive from v$sql where sql_id = 'dh11gtgpduy1b';
PLAN_HASH_VALUE CHILD_NUMBER INVALIDATIONS EXECUTIONS I I
--------------- ------------ ------------- ---------- - -
3051237957 0 0 1 N N
SCOTT@book> select object_name, object_type, sysdate as now, last_ddl_time from dba_objects where object_name = 'DEPT' and owner = user;
OBJECT_NAME OBJECT_TYPE NOW LAST_DDL_TIME
-------------------- ------------------- ------------------- -------------------
DEPT TABLE 2020-11-05 08:47:56 2020-03-25 10:08:55
SCOTT@book> select degree from dba_tables where owner = user and table_name = 'DEPT';
DEGREE
--------------------
1
SCOTT@book> alter table dept noparallel;
Table altered.
SCOTT@book> select degree from dba_tables where owner = user and table_name = 'DEPT';
DEGREE
--------------------
1
--//可以發現DEGREE沒有變化。
SCOTT@book> select object_name, object_type, sysdate as now, last_ddl_time from dba_objects where object_name = 'DEPT' and owner = user;
OBJECT_NAME OBJECT_TYPE NOW LAST_DDL_TIME
-------------------- ------------------- ------------------- -------------------
DEPT TABLE 2020-11-05 08:50:27 2020-11-05 08:49:08
--//LAST_DDL_TIME發生了變化。
SCOTT@book> select count(*) from dept ;
COUNT(*)
----------
4
SCOTT@book> select plan_hash_value, child_number, invalidations, executions, is_bind_aware, is_bind_sensitive from v$sql where sql_id = 'dh11gtgpduy1b';
PLAN_HASH_VALUE CHILD_NUMBER INVALIDATIONS EXECUTIONS I I
--------------- ------------ ------------- ---------- - -
3051237957 0 1 1 N N
--//可以發現重新分析sql語句。而且並沒有生成新的子游標CHILD_NUMBER=0,作者最後的結論:
Remember that a DML operation as the one shown in this post is a blunt weapon and only to be used as a last resort.
--//請記住,DML操作,如本文所示,是一種鈍器,僅作為最後手段使用。
--//實際上如果想想也許還能想出許多方法。
--//當然這樣的方式導致只要涉及到這個表的sql語句都要重新分析。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/267265/viewspace-2732251/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- [20170703]SQL語句分析執行過程.txtSQL
- [20150403]修正sql語句.txtSQL
- sql語句的優化分析SQL優化
- 使用sql語句分析雙色球SQL
- 透過sql語句分析足彩SQL
- 通過sql語句分析足彩SQL
- 用EXPLAIN PLAN 分析SQL語句AISQL
- [20211221]分析sql語句遇到的問題.txtSQL
- [20210923]sql語句佔用Sharable Memory分析.txtSQL
- [20181119]sql語句執行緩慢分析.txtSQL
- 通過分析SQL語句的執行計劃優化SQL語句SQL優化
- [20170103]sql語句過載.txtSQL
- sql語句執行緩慢分析SQL
- SQL語句優化技術分析SQL優化
- sql語句的優化案例分析SQL優化
- 分析後sql語句很快返回結果SQL
- SQL語句最佳化技術分析SQL
- ORACLE SQL語句優化技術分析OracleSQL優化
- SQL語句SQL
- Java中如何解析SQL語句、格式化SQL語句、生成SQL語句?JavaSQL
- [20210407]分析sql語句的共享記憶體段3.txtSQL記憶體
- [20131204]sql語句優化.txtSQL優化
- [20151221]sql語句優化.txtSQL優化
- [20141013]奇怪的sql語句.txtSQL
- [20150527]跟蹤單個sql語句.txtSQL
- [20121101]tkprof抽取sql語句.txtSQL
- [20240320]空格與sqlpus的sql語句.txtSQL
- [20200424]跟蹤特定sql語句以及v$open_cursor檢視(再補充).txtSQL
- [20240607]PL/SQL中sql語句的註解.txtSQL
- Oracle SQL語句最佳化技術分析OracleSQL
- ORACLE SQL語句優化技術分析(zt)OracleSQL優化
- ORACLE SQL語句優化技術分析(轉)OracleSQL優化
- [20200326]dbms_monitor跟蹤與SQL語句分析.txtSQL
- sql語句大全SQL
- 共享SQL語句SQL
- SQL語句整理SQL
- SQL基本語句SQL
- 精妙Sql語句SQL