[20220329]19c sql語句打補丁.txt
[20220329]19c sql語句打補丁.txt
--//在19c最佳化sql語句使用sql profile模式交換執行計劃時,出現無法穩定執行計劃的情況。
--//嘗試打補丁的方式,19c以上版本與以前11g的命令有一點點不同,做一個簡單記錄。
1.環境:
> @pr
==============================
PORT_STRING : x86_64/Linux 2.4.xx
VERSION : 19.0.0.0.0
BANNER : Oracle Database 19c Enterprise Edition Release 19.0.0.0.0 - Production
BANNER_FULL : Oracle Database 19c Enterprise Edition Release 19.0.0.0.0 - Production
Version 19.9.0.0.0
BANNER_LEGACY : Oracle Database 19c Enterprise Edition Release 19.0.0.0.0 - Production
CON_ID : 0
PL/SQL procedure successfully completed.
1.打補丁:
--//首先確定sql_id,執行如下命令:
DECLARE
v_sql CLOB;
patch_name VARCHAR2 (100);
BEGIN
SELECT SQL_FULLTEXT
INTO v_sql
FROM v$sql
WHERE sql_id = '&sql_id' AND ROWNUM = 1;
patch_name :=
sys.DBMS_SQLDIAG.create_sql_patch
(
sql_text => v_sql
,hint_text => 'USE_CONCAT(@"SEL$2BFA4EE4" 8 OR_PREDICATES(5)))'
,name => 'user_extents_patch &sql_id'
);
END;
/
--//說明:我以前寫的指令碼使用SQL_TEXT,實際上其型別VARCHAR2(1000),不是clob,做測試可以,生產系統語句一般都很長不行。
--//以前11g使用sys.dbms_sqldiag_internal.i_create_patch,這個是一個儲存過程,呼叫就ok了,無法定義變數patch_name。
YS@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
SYS@book> @ desc sys.dbms_sqldiag_internal
PROCEDURE I_CREATE_HINTSET
Argument Name Type In/Out Default?
------------------------------ ----------------------- ------ --------
SQL_TEXT CLOB IN
HINT_TEXT VARCHAR2 IN
NAME VARCHAR2 IN DEFAULT
DESCRIPTION VARCHAR2 IN DEFAULT
CATEGORY VARCHAR2 IN DEFAULT
VALIDATE BOOLEAN IN DEFAULT
PROCEDURE I_CREATE_PATCH
~~~~~~~~~~~~~~~~~~~~~~~~
Argument Name Type In/Out Default?
------------------------------ ----------------------- ------ --------
SQL_TEXT CLOB IN
HINT_TEXT VARCHAR2 IN
NAME VARCHAR2 IN DEFAULT
DESCRIPTION VARCHAR2 IN DEFAULT
CATEGORY VARCHAR2 IN DEFAULT
VALIDATE BOOLEAN IN DEFAULT
FUNCTION I_GENERATE_SS_IMPORT RETURNS VARCHAR2
FUNCTION I_GET_DBVERSION RETURNS VARCHAR2
FUNCTION I_GET_INCIDENTID RETURNS NUMBER
Argument Name Type In/Out Default?
------------------------------ ----------------------- ------ --------
ID VARCHAR2 IN
PROCEDURE I_INCIDENTID_2_SQL
Argument Name Type In/Out Default?
------------------------------ ----------------------- ------ --------
INCIDENT_ID VARCHAR2 IN
SQL_STMT SQLSET_ROW OUT
PROBLEM_TYPE NUMBER OUT
ERR_CODE BINARY_INTEGER OUT
ERR_MESG VARCHAR2 OUT
--//而19c使用sys.dbms_sqldiag包,CREATE_SQL_PATCH是一個函式,需要一個變數接收返回。
> @ desc sys.dbms_sqldiag
...
FUNCTION CREATE_SQL_PATCH RETURNS VARCHAR2
Argument Name Type In/Out Default?
------------------------------ ----------------------- ------ --------
SQL_ID VARCHAR2 IN
HINT_TEXT CLOB IN
NAME VARCHAR2 IN DEFAULT
DESCRIPTION VARCHAR2 IN DEFAULT
CATEGORY VARCHAR2 IN DEFAULT
VALIDATE BOOLEAN IN DEFAULT
2.檢視打補丁資訊:
$ cat spext.sql
/* Formatted on 2015/4/10 17:03:49 (QP5 v5.252.13127.32867) */
column hint format a200
column name format a30
SELECT EXTRACTVALUE (VALUE (h), '.') AS hint,so.name
FROM SYS.sqlobj$data od
,SYS.sqlobj$ so
,TABLE
(
XMLSEQUENCE
(
EXTRACT (XMLTYPE (od.comp_data), '/outline_data/hint')
)
) h
WHERE ( so.NAME in ( 'profile &&1', 'tuning &&1','switch tuning &&1') or lower(so.name) like lower('%&&1%'))
AND so.signature = od.signature
AND so.CATEGORY = od.CATEGORY
AND so.obj_type = od.obj_type
AND so.plan_id = od.plan_id;
> @ spext gk5ttf0jpf88k
HINT NAME
------------------------------------------------ ------------------------------
USE_CONCAT(@"SEL$2BFA4EE4" 8 OR_PREDICATES(5))) user_extents_patch gk5ttf0jpf88k
3.刪除sql補丁執行如下:
exec sys.dbms_sqldiag.drop_sql_patch('user_extents_patch &sql_id');
4.檢查是否生效:
@ dpc gk5ttf0jpf88k outline ''
--//始終搞不明白為什麼sql profile交換執行計劃不行。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/267265/viewspace-2884795/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- [20220329]是否開發寫錯sql語句.txtSQL
- [202021127]sql打補丁問題.txtSQL
- [20220330]編寫sql打補丁的指令碼.txtSQL指令碼
- [20210929]sql打補丁使用rule提示問題.txtSQL
- 19c 自動打RU補丁
- [20220119]超長sql語句補充3.txtSQL
- [20220120]超長sql語句補充4.txtSQL
- 19c rac自動打補丁步驟
- [20201126]使用cursor_sharing_exact與給sql打補丁2.txtSQL
- [20201126]使用cursor_sharing_exact與給sql打補丁3.txtSQL
- oracle 19c rac打補丁常見錯誤Oracle
- [20190329]探究sql語句相關mutexes補充2.txtSQLMutex
- Oracle 19c RAC打補丁過程避坑指南Oracle
- [20201105]再分析sql語句.txtSQL
- [20220117]超長sql語句.txtSQL
- [20201210]sql語句優化.txtSQL優化
- [20220331]如何調整sql語句.txtSQL
- 如何給esxi打補丁
- Linux檔案打補丁Linux
- oracle打補丁回顧Oracle
- [20240607]PL/SQL中sql語句的註解.txtSQL
- [20200422]跟蹤特定sql語句以及v$open_cursor檢視(補充).txtSQL
- [20240320]空格與sqlpus的sql語句.txtSQL
- [20200320]SQL語句優化的困惑.txtSQL優化
- ORACLE 19C RAC FOR RHEL7 打補丁報錯OPatchException: Unable to create patchObjectOracleExceptionObject
- weblogic的版本及打補丁Web
- DG環境下打補丁
- [20200424]跟蹤特定sql語句以及v$open_cursor檢視(再補充).txtSQL
- 【補丁】Oracle補丁的知識及術語Oracle
- [20181119]sql語句執行緩慢分析.txtSQL
- [20181114]一條sql語句的優化.txtSQL優化
- [20211221]分析sql語句遇到的問題.txtSQL
- [20210923]sql語句佔用Sharable Memory分析.txtSQL
- [20211009]使用bash計算sql語句的sql_id.txtSQL
- 打補丁時重建Inventory目錄
- ORACLE打補丁的方法和案例Oracle
- Oracle RAC 19.3打19.5.1 RU補丁Oracle
- windows oracle 11201打補丁報錯WindowsOracle