flush sql

jichengjie發表於2017-07-18
如果Oracle的最佳化器產生了某種錯誤的執行計劃,或者我們希望Oracle對於某個SQL重新進行分析,那麼就需要這個SQL的執行計劃在共享池中過期。
在業務時段不可能使用alter system flush shared_pool的方式
SQL>  select sql_id, address, hash_value, executions, loads, parse_calls, invalidations from v$sqlarea where lower(sql_text) like '%test%';


SQL_ID        ADDRESS          HASH_VALUE EXECUTIONS      LOADS PARSE_CALLS
------------- ---------------- ---------- ---------- ---------- -----------
INVALIDATIONS
-------------
bmgz3h5qtng75 000000007866D210 1838824677          1          4           1
            3


0kxrz1ugtjpkm 00000000783DD930 2677593683          1          1           1
            0


bb926a5dcb8kr 0000000078941CE0 1522901591         21          2          21
            0




SQL_ID        ADDRESS          HASH_VALUE EXECUTIONS      LOADS PARSE_CALLS
------------- ---------------- ---------- ---------- ---------- -----------
INVALIDATIONS
-------------
a5ks9fhw2v9s1 0000000079701150  942515961          1          1           1
            0




SQL> exec dbms_shared_pool.purge('0000000079701150,942515961','c');


PL/SQL procedure successfully completed.


SQL>  select sql_id, address, hash_value, executions, loads, parse_calls, invalidations from v$sqlarea where lower(sql_text) like '%test%';


SQL_ID        ADDRESS          HASH_VALUE EXECUTIONS      LOADS PARSE_CALLS
------------- ---------------- ---------- ---------- ---------- -----------
INVALIDATIONS
-------------
bmgz3h5qtng75 000000007866D210 1838824677          1          4           1
            3


0kxrz1ugtjpkm 00000000783DD930 2677593683          2          1           2
            0


bb926a5dcb8kr 0000000078941CE0 1522901591         21          2          21
            0




來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/26870952/viewspace-2142218/,如需轉載,請註明出處,否則將追究法律責任。

相關文章