[20190430]注意sql hint寫法.txt
[20190430]注意sql hint寫法.txt
--//連結:
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
SCOTT@book> @ sqlhint cache
old 1: select * from V$SQL_HINT where name like upper('%&1%')
new 1: select * from V$SQL_HINT where name like upper('%cache%')
NAME SQL_FEATURE CLASS INVERSE TARGET_LEVEL PROPERTY VERSION VERSION_OUTLINE
---------------- --------------- ------------ --------------- ------------ ---------- -------- ----------------
CACHE_CB QKSFM_CBO CACHE_CB NOCACHE 4 256 8.1.5
CACHE QKSFM_EXECUTION CACHE NOCACHE 4 256 8.1.0
NOCACHE QKSFM_EXECUTION CACHE CACHE 4 256 8.1.0
CACHE_TEMP_TABLE QKSFM_ALL CACHE NOCACHE 4 256 8.1.5
RESULT_CACHE QKSFM_EXECUTION RESULT_CACHE NO_RESULT_CACHE 2 0 11.1.0.6
NO_RESULT_CACHE QKSFM_EXECUTION RESULT_CACHE RESULT_CACHE 2 0 11.1.0.6
6 rows selected.
SCOTT@book> select /*+ result cache */ * from dept ;
DEPTNO DNAME LOC
---------- -------------- -------------
10 ACCOUNTING NEW YORK
20 RESEARCH DALLAS
30 SALES CHICAGO
40 OPERATIONS BOSTON
--//注意中間沒有"_".
SCOTT@book> @ dpc '' ''
PLAN_TABLE_OUTPUT
-------------------------------------
SQL_ID 5sm6uuf1wtunm, child number 0
-------------------------------------
select /*+ result cache */ * from dept
Plan hash value: 3383998547
---------------------------------------------------------------------------
| Id | Operation | Name | E-Rows |E-Bytes| Cost (%CPU)| E-Time |
---------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | | | 3 (100)| |
| 1 | TABLE ACCESS FULL| DEPT | 4 | 80 | 3 (0)| 00:00:01 |
---------------------------------------------------------------------------
Query Block Name / Object Alias (identified by operation id):
-------------------------------------------------------------
1 - SEL$1 / DEPT@SEL$1
SCOTT@book> select /*+ result_cache */ * from dept ;
DEPTNO DNAME LOC
---------- -------------- -------------
10 ACCOUNTING NEW YORK
20 RESEARCH DALLAS
30 SALES CHICAGO
40 OPERATIONS BOSTON
SCOTT@book> @ dpc '' ''
PLAN_TABLE_OUTPUT
-------------------------------------
SQL_ID dh09kah6tkdjy, child number 0
-------------------------------------
select /*+ result_cache */ * from dept
Plan hash value: 3383998547
--------------------------------------------------------------------------------------------------
| Id | Operation | Name | E-Rows |E-Bytes| Cost (%CPU)| E-Time |
--------------------------------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | | | 3 (100)| |
| 1 | RESULT CACHE | gsg6g7y8rvxaydjyjh2g2yr21r | | | | |
| 2 | TABLE ACCESS FULL| DEPT | 4 | 80 | 3 (0)| 00:00:01 |
--------------------------------------------------------------------------------------------------
Query Block Name / Object Alias (identified by operation id):
-------------------------------------------------------------
1 - SEL$1
2 - SEL$1 / DEPT@SEL$1
--//連結:也提到一種情況:
--//我沒有19c.
SCOTT@book> select /*+ use_nl(emp dept) */ * from dept ,emp where dept.deptno=emp.deptno;
...
SCOTT@book> @ dpc '' ''
PLAN_TABLE_OUTPUT
-------------------------------------
SQL_ID gk5d852xxj4b5, child number 0
-------------------------------------
select /*+ use_nl(emp dept) */ * from dept ,emp where
dept.deptno=emp.deptno
Plan hash value: 4192419542
----------------------------------------------------------------------------
| Id | Operation | Name | E-Rows |E-Bytes| Cost (%CPU)| E-Time |
----------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | | | 10 (100)| |
| 1 | NESTED LOOPS | | 14 | 812 | 10 (0)| 00:00:01 |
| 2 | TABLE ACCESS FULL| DEPT | 4 | 80 | 3 (0)| 00:00:01 |
|* 3 | TABLE ACCESS FULL| EMP | 4 | 152 | 2 (0)| 00:00:01 |
----------------------------------------------------------------------------
Query Block Name / Object Alias (identified by operation id):
-------------------------------------------------------------
1 - SEL$1
2 - SEL$1 / DEPT@SEL$1
3 - SEL$1 / EMP@SEL$1
Predicate Information (identified by operation id):
---------------------------------------------------
3 - filter("DEPT"."DEPTNO"="EMP"."DEPTNO")
--//注意看執行計劃,實際上主驅動dept表.只有寫成如下:
SCOTT@book> select /*+ use_nl(emp ) */ * from dept ,emp where dept.deptno=emp.deptno;
..
Plan hash value: 1123238657
-------------------------------------------------------------------------------------------------------
| Id | Operation | Name | E-Rows |E-Bytes| Cost (%CPU)| E-Time | OMem | 1Mem | Used-Mem |
-------------------------------------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | | | 6 (100)| | | | |
|* 1 | HASH JOIN | | 14 | 812 | 6 (0)| 00:00:01 | 1048K| 1048K| 662K (0)|
| 2 | TABLE ACCESS FULL| EMP | 14 | 532 | 3 (0)| 00:00:01 | | | |
| 3 | TABLE ACCESS FULL| DEPT | 4 | 80 | 3 (0)| 00:00:01 | | | |
-------------------------------------------------------------------------------------------------------
--//這樣emp才能作為驅動表.
--//最後一種情況是我經常犯的錯誤..
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/267265/viewspace-2642961/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- [20200718]注意sql hint寫法2.txtSQL
- [20200801]sql hint衝突.txtSQL
- 【sql hint 提示】SQL
- sql hint articleSQL
- Oralce SQL hintSQL
- Oracle SQL寫法OracleSQL
- MySQL SQL hint 提示MySql
- sql寫法小記SQL
- Oracle中的sql hintOracleSQL
- GreatSQL 在SQL中使用 HINT 語法修改會話變數SQL會話變數
- 【HINT】使用“NO_INDEX ”Hint提示避免SQL使用特定索引IndexSQL索引
- 個人線段樹寫法 & 注意逝項
- SQL常用的特殊寫法SQL
- openGauss 支援SQL-hintSQL
- Oracle PL/SQL編寫PL/SQL程式碼的注意事項OracleSQL
- 【sql調優之執行計劃】使用hint(五)Hint for parallelSQLParallel
- 檢視SQL PROFILE使用的HINTSQL
- 11G new SQL hint大全SQL
- oracle 通過sql profile為sql語句加hintOracleSQL
- SQL語句規範的寫法SQL
- Mysql 分組排序的sql寫法MySql排序
- OCI插入SQL語句的寫法SQL
- Oracle 12c 新SQL提示(hint)OracleSQL
- 使用hint來調優sql語句SQL
- 資料分佈決定SQL寫法SQL
- 許可權控制下的SQL寫法SQL
- Sql最佳化(五) hint(提示)介紹SQL
- 通過hint push_subq優化sql優化SQL
- sql調優一例---索引排序hintSQL索引排序
- 關於append sql hint的實驗APPSQL
- SQL hint中正確使用use_nl提示SQL
- ORACLE常用SQL最佳化hint語句OracleSQL
- 【丁原】分頁sql中普通寫法和rowid寫法的效能比較SQL
- 關於號段選取的sql寫法SQL
- Update 多個關聯表SQL的寫法SQL
- ORACLE 通過SPM為SQL語句加HINTOracleSQL
- 透過使用hint unnest調優sql語句SQL
- 通過使用hint unnest調優sql語句SQL