处理半连接SQL自动改写内连接SQL一例
昨天刚写了半连接改写系列,今天就遇到了此类型SQL:
优化前
耗时:28s
返回:0
SELECT D.DAILYAUDITNO, D.TRANSTOACC
FROM PB_DOIC.MM_DAILYREPORT_TD D
WHERE D.REPORTSTATUS = '4'
AND D.TRANSTOACC IN ('00', 'B1')
AND EXISTS (SELECT 1
FROM PB_DOIC.MM_DAILYREPORT_DETAIL_TD
WHERE DAILYAUDITNO = D.DAILYAUDITNO
AND BUSINESSONE || BUSINESSTWO NOT IN
('604988', '605988', '606988', '607988')
AND BUSINESSTWO != '991')
AND NOT EXISTS
(SELECT 1
FROM PB_DOIC.MM_DAILYREPORT_DETAIL_TD E
WHERE E.DAILYAUDITNO = D.DAILYAUDITNO
AND E.BUSINESSONE || E.BUSINESSTWO NOT IN
('604988', '605988', '606988', '607988')
AND E.BUSINESSTWO != '991'
AND NOT EXISTS
(SELECT 1
FROM PB_DOIC.MM_VOUCHERMODULE_TC V
WHERE V.BUSINESSTYPE = E.BUSINESSONE || E.BUSINESSTWO
AND V.MODULETYPE = '1'
AND V.MODULESTATUS = 0))
FOR UPDATE OF D.TRANSTOACC NOWAIT
Execution Plan
----------------------------------------------------------
Plan hash value: 915590932
--------------------------------------------------------------------------------------------------------------
| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |
--------------------------------------------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | 10 | 1160 | 20991 (2)| 00:04:12 |
| 1 | FOR UPDATE | | | | | |
| 2 | NESTED LOOPS | | 1 | 116 | 20945 (2)| 00:04:12 |
| 3 | SORT UNIQUE | | 29 | 1943 | 20928 (2)| 00:04:12 |
|* 4 | INDEX FAST FULL SCAN | IDX_MM_DAILYREPORT_DETAIL_TD | 29 | 1943 | 20928 (2)| 00:04:12 |
|* 5 | TABLE ACCESS BY INDEX ROWID| MM_DAILYREPORT_TD | 1 | 49 | 2 (0)| 00:00:01 |
|* 6 | INDEX UNIQUE SCAN | PK_MM_DAILYREPORT_TD | 1 | | 1 (0)| 00:00:01 |
|* 7 | INDEX RANGE SCAN | IDX_MM_DAILYREPORT_DETAIL_TD | 1 | 67 | 7 (0)| 00:00:01 |
|* 8 | INDEX RANGE SCAN | PK_MM_VOUCHERMODULE_TC | 1 | 15 | 2 (0)| 00:00:01 |
--------------------------------------------------------------------------------------------------------------
Predicate Information (identified by operation id):
---------------------------------------------------
4 - filter("BUSINESSONE"||"BUSINESSTWO"<>'604988' AND "BUSINESSONE"||"BUSINESSTWO"<>'605988' AND
"BUSINESSONE"||"BUSINESSTWO"<>'606988' AND "BUSINESSONE"||"BUSINESSTWO"<>'607988' AND
"BUSINESSTWO"<>'991')
5 - filter(("D"."TRANSTOACC"='00' OR "D"."TRANSTOACC"='B1') AND "D"."REPORTSTATUS"='4')
6 - access("DAILYAUDITNO"="D"."DAILYAUDITNO")
filter( NOT EXISTS (SELECT /*+ */ 0 FROM "PB_DOIC"."MM_DAILYREPORT_DETAIL_TD" "SYS_ALIAS_2"
WHERE "E"."DAILYAUDITNO"=:B1 AND "E"."BUSINESSONE"||"E"."BUSINESSTWO"<>'604988' AND
"E"."BUSINESSONE"||"E"."BUSINESSTWO"<>'605988' AND "E"."BUSINESSONE"||"E"."BUSINESSTWO"<>'606988' AND
"E"."BUSINESSONE"||"E"."BUSINESSTWO"<>'607988' AND "E"."BUSINESSTWO"<>'991' AND NOT EXISTS (SELECT
/*+ */ 0 FROM "PB_DOIC"."MM_VOUCHERMODULE_TC" "V" WHERE "V"."BUSINESSTYPE"=:B2||:B3 AND
"V"."MODULETYPE"='1' AND "V"."MODULESTATUS"=0)))
7 - access("E"."DAILYAUDITNO"=:B1)
filter("E"."BUSINESSONE"||"E"."BUSINESSTWO"<>'604988' AND
"E"."BUSINESSONE"||"E"."BUSINESSTWO"<>'605988' AND "E"."BUSINESSONE"||"E"."BUSINESSTWO"<>'606988' AND
"E"."BUSINESSONE"||"E"."BUSINESSTWO"<>'607988' AND "E"."BUSINESSTWO"<>'991' AND NOT EXISTS (SELECT
/*+ */ 0 FROM "PB_DOIC"."MM_VOUCHERMODULE_TC" "V" WHERE "V"."BUSINESSTYPE"=:B1||:B2 AND
"V"."MODULETYPE"='1' AND "V"."MODULESTATUS"=0))
8 - access("V"."MODULETYPE"='1' AND "V"."BUSINESSTYPE"=:B1||:B2 AND "V"."MODULESTATUS"=0)
filter("V"."MODULESTATUS"=0)
Statistics
----------------------------------------------------------
1 recursive calls
0 db block gets
3809828 consistent gets
347 physical reads
0 redo size
397 bytes sent via SQL*Net to client
481 bytes received via SQL*Net from client
1 SQL*Net roundtrips to/from client
1 sorts (memory)
0 sorts (disk)
0 rows processed
分析
查看执行计划,发现ID=3处为 SORT UNIQUE ,而SQL语句并没有DISTINCT关键字,难道SQL进行自动改写了?
为了确认自己想法,我进行以下手动改写,把半连接手动改写成内连接:
改写之前,先确认表与表之间的关系:
select count(*),count(distinct DAILYAUDITNO) from MM_DAILYREPORT_DETAIL_TD;
COUNT(*) COUNT(DISTINCTDAILYAUDITNO)
-------- -----------------------
5111081 441898
select count(*),count(distinct DAILYAUDITNO) from MM_DAILYREPORT_TD;
COUNT(*) COUNT(DISTINCTDAILYAUDITNO)
-------- -----------------------
441940 441940
--表MM_DAILYREPORT_TD与表MM_DAILYREPORT_DETAIL_TD是1:N的关系,所以改写时候,需要先去重,再连接。
SELECT D.DAILYAUDITNO, D.TRANSTOACC
FROM PB_DOIC.MM_DAILYREPORT_TD D
INNER JOIN (SELECT DISTINCT DAILYAUDITNO
FROM PB_DOIC.MM_DAILYREPORT_DETAIL_TD
WHERE BUSINESSONE || BUSINESSTWO NOT IN
('604988', '605988', '606988', '607988')
AND BUSINESSTWO != '991') TD
ON D.DAILYAUDITNO = TD.DAILYAUDITNO
WHERE D.REPORTSTATUS = '4'
AND D.TRANSTOACC IN ('00', 'B1')
AND NOT EXISTS
(SELECT 1
FROM PB_DOIC.MM_DAILYREPORT_DETAIL_TD E
WHERE E.DAILYAUDITNO = D.DAILYAUDITNO
AND E.BUSINESSONE || E.BUSINESSTWO NOT IN
('604988', '605988', '606988', '607988')
AND E.BUSINESSTWO != '991'
AND NOT EXISTS
(SELECT 1
FROM PB_DOIC.MM_VOUCHERMODULE_TC V
WHERE V.BUSINESSTYPE = E.BUSINESSONE || E.BUSINESSTWO
AND V.MODULETYPE = '1'
AND V.MODULESTATUS = 0))
FOR UPDATE OF D.TRANSTOACC NOWAIT;
Execution Plan
----------------------------------------------------------
Plan hash value: 1310135718
--------------------------------------------------------------------------------------------------------------
| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |
--------------------------------------------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | 25 | 2250 | 21076 (2)| 00:04:13 |
| 1 | FOR UPDATE | | | | | |
| 2 | NESTED LOOPS | | 1 | 90 | 20959 (2)| 00:04:12 |
| 3 | VIEW | | 29 | 1189 | 20929 (2)| 00:04:12 |
| 4 | SORT UNIQUE | | 29 | 1943 | 20929 (2)| 00:04:12 |
|* 5 | INDEX FAST FULL SCAN | IDX_MM_DAILYREPORT_DETAIL_TD | 29 | 1943 | 20928 (2)| 00:04:12 |
|* 6 | TABLE ACCESS BY INDEX ROWID| MM_DAILYREPORT_TD | 1 | 49 | 2 (0)| 00:00:01 |
|* 7 | INDEX UNIQUE SCAN | PK_MM_DAILYREPORT_TD | 1 | | 1 (0)| 00:00:01 |
|* 8 | INDEX RANGE SCAN | IDX_MM_DAILYREPORT_DETAIL_TD | 1 | 67 | 7 (0)| 00:00:01 |
|* 9 | INDEX RANGE SCAN | PK_MM_VOUCHERMODULE_TC | 1 | 15 | 2 (0)| 00:00:01 |
--------------------------------------------------------------------------------------------------------------
Predicate Information (identified by operation id):
---------------------------------------------------
5 - filter("BUSINESSONE"||"BUSINESSTWO"<>'604988' AND "BUSINESSONE"||"BUSINESSTWO"<>'605988' AND
"BUSINESSONE"||"BUSINESSTWO"<>'606988' AND "BUSINESSONE"||"BUSINESSTWO"<>'607988' AND
"BUSINESSTWO"<>'991')
6 - filter(("D"."TRANSTOACC"='00' OR "D"."TRANSTOACC"='B1') AND "D"."REPORTSTATUS"='4')
7 - access("D"."DAILYAUDITNO"="TD"."DAILYAUDITNO")
filter( NOT EXISTS (SELECT /*+ */ 0 FROM "PB_DOIC"."MM_DAILYREPORT_DETAIL_TD" "SYS_ALIAS_2"
WHERE "E"."DAILYAUDITNO"=:B1 AND "E"."BUSINESSONE"||"E"."BUSINESSTWO"<>'604988' AND
"E"."BUSINESSONE"||"E"."BUSINESSTWO"<>'605988' AND "E"."BUSINESSONE"||"E"."BUSINESSTWO"<>'606988' AND
"E"."BUSINESSONE"||"E"."BUSINESSTWO"<>'607988' AND "E"."BUSINESSTWO"<>'991' AND NOT EXISTS (SELECT
/*+ */ 0 FROM "PB_DOIC"."MM_VOUCHERMODULE_TC" "V" WHERE "V"."BUSINESSTYPE"=:B2||:B3 AND
"V"."MODULETYPE"='1' AND "V"."MODULESTATUS"=0)))
8 - access("E"."DAILYAUDITNO"=:B1)
filter("E"."BUSINESSONE"||"E"."BUSINESSTWO"<>'604988' AND
"E"."BUSINESSONE"||"E"."BUSINESSTWO"<>'605988' AND "E"."BUSINESSONE"||"E"."BUSINESSTWO"<>'606988' AND
"E"."BUSINESSONE"||"E"."BUSINESSTWO"<>'607988' AND "E"."BUSINESSTWO"<>'991' AND NOT EXISTS (SELECT
/*+ */ 0 FROM "PB_DOIC"."MM_VOUCHERMODULE_TC" "V" WHERE "V"."BUSINESSTYPE"=:B1||:B2 AND
"V"."MODULETYPE"='1' AND "V"."MODULESTATUS"=0))
9 - access("V"."MODULETYPE"='1' AND "V"."BUSINESSTYPE"=:B1||:B2 AND "V"."MODULESTATUS"=0)
filter("V"."MODULESTATUS"=0)
Statistics
----------------------------------------------------------
1 recursive calls
0 db block gets
3809828 consistent gets
431 physical reads
0 redo size
397 bytes sent via SQL*Net to client
481 bytes received via SQL*Net from client
1 SQL*Net roundtrips to/from client
1 sorts (memory)
0 sorts (disk)
0 rows processed
可以看出改写后的执行计划于改写之前执行计划基本一致,所以可以确定SQL是进行自动改写内连接而导致的性能问题。
优化方法1:
耗时:0.4s
返回:0
--在半连接里加上ROWNUM>0,让SQL不进行展开。
SELECT D.DAILYAUDITNO, D.TRANSTOACC
FROM PB_DOIC.MM_DAILYREPORT_TD D
WHERE D.REPORTSTATUS = '4'
AND D.TRANSTOACC IN ('00', 'B1')
AND EXISTS (SELECT 1
FROM PB_DOIC.MM_DAILYREPORT_DETAIL_TD
WHERE DAILYAUDITNO = D.DAILYAUDITNO
AND BUSINESSONE || BUSINESSTWO NOT IN
('604988', '605988', '606988', '607988')
AND BUSINESSTWO != '991' AND ROWNUM>0)
AND NOT EXISTS
(SELECT 1
FROM PB_DOIC.MM_DAILYREPORT_DETAIL_TD E
WHERE E.DAILYAUDITNO = D.DAILYAUDITNO
AND E.BUSINESSONE || E.BUSINESSTWO NOT IN
('604988', '605988', '606988', '607988')
AND E.BUSINESSTWO != '991'
AND NOT EXISTS
(SELECT 1
FROM PB_DOIC.MM_VOUCHERMODULE_TC V
WHERE V.BUSINESSTYPE = E.BUSINESSONE || E.BUSINESSTWO
AND V.MODULETYPE = '1'
AND V.MODULESTATUS = 0))
FOR UPDATE OF D.TRANSTOACC NOWAIT;
Execution Plan
----------------------------------------------------------
Plan hash value: 4088075167
------------------------------------------------------------------------------------------------------
| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |
------------------------------------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | 1 | 49 | 336K (1)| 01:07:15 |
| 1 | FOR UPDATE | | | | | |
|* 2 | FILTER | | | | | |
|* 3 | TABLE ACCESS FULL | MM_DAILYREPORT_TD | 22372 | 1070K| 2632 (2)| 00:00:32 |
| 4 | COUNT | | | | | |
|* 5 | FILTER | | | | | |
|* 6 | INDEX RANGE SCAN | IDX_MM_DAILYREPORT_DETAIL_TD | 1 | 67 | 7 (0)| 00:00:01 |
|* 7 | INDEX RANGE SCAN | IDX_MM_DAILYREPORT_DETAIL_TD | 1 | 67 | 7 (0)| 00:00:01 |
|* 8 | INDEX RANGE SCAN| PK_MM_VOUCHERMODULE_TC | 1 | 15 | 2 (0)| 00:00:01 |
------------------------------------------------------------------------------------------------------
Predicate Information (identified by operation id):
---------------------------------------------------
2 - filter( EXISTS (SELECT /*+ */ 0 FROM "PB_DOIC"."MM_DAILYREPORT_DETAIL_TD"
"MM_DAILYREPORT_DETAIL_TD" WHERE ROWNUM>0 AND "DAILYAUDITNO"=:B1 AND
"BUSINESSONE"||"BUSINESSTWO"<>'604988' AND "BUSINESSONE"||"BUSINESSTWO"<>'605988' AND
"BUSINESSONE"||"BUSINESSTWO"<>'606988' AND "BUSINESSONE"||"BUSINESSTWO"<>'607988' AND
"BUSINESSTWO"<>'991') AND NOT EXISTS (SELECT /*+ */ 0 FROM
"PB_DOIC"."MM_DAILYREPORT_DETAIL_TD" "SYS_ALIAS_2" WHERE "E"."DAILYAUDITNO"=:B2 AND
"E"."BUSINESSONE"||"E"."BUSINESSTWO"<>'604988' AND
"E"."BUSINESSONE"||"E"."BUSINESSTWO"<>'605988' AND
"E"."BUSINESSONE"||"E"."BUSINESSTWO"<>'606988' AND
"E"."BUSINESSONE"||"E"."BUSINESSTWO"<>'607988' AND "E"."BUSINESSTWO"<>'991' AND NOT EXISTS
(SELECT /*+ */ 0 FROM "PB_DOIC"."MM_VOUCHERMODULE_TC" "V" WHERE "V"."BUSINESSTYPE"=:B3||:B4
AND "V"."MODULETYPE"='1' AND "V"."MODULESTATUS"=0)))
3 - filter(("D"."TRANSTOACC"='00' OR "D"."TRANSTOACC"='B1') AND "D"."REPORTSTATUS"='4')
5 - filter(ROWNUM>0)
6 - access("DAILYAUDITNO"=:B1)
filter("BUSINESSONE"||"BUSINESSTWO"<>'604988' AND
"BUSINESSONE"||"BUSINESSTWO"<>'605988' AND "BUSINESSONE"||"BUSINESSTWO"<>'606988' AND
"BUSINESSONE"||"BUSINESSTWO"<>'607988' AND "BUSINESSTWO"<>'991')
7 - access("E"."DAILYAUDITNO"=:B1)
filter("E"."BUSINESSONE"||"E"."BUSINESSTWO"<>'604988' AND
"E"."BUSINESSONE"||"E"."BUSINESSTWO"<>'605988' AND
"E"."BUSINESSONE"||"E"."BUSINESSTWO"<>'606988' AND
"E"."BUSINESSONE"||"E"."BUSINESSTWO"<>'607988' AND "E"."BUSINESSTWO"<>'991' AND NOT EXISTS
(SELECT /*+ */ 0 FROM "PB_DOIC"."MM_VOUCHERMODULE_TC" "V" WHERE "V"."BUSINESSTYPE"=:B1||:B2
AND "V"."MODULETYPE"='1' AND "V"."MODULESTATUS"=0))
8 - access("V"."MODULETYPE"='1' AND "V"."BUSINESSTYPE"=:B1||:B2 AND "V"."MODULESTATUS"=0)
filter("V"."MODULESTATUS"=0)
Statistics
----------------------------------------------------------
0 recursive calls
0 db block gets
105048 consistent gets
0 physical reads
0 redo size
397 bytes sent via SQL*Net to client
481 bytes received via SQL*Net from client
1 SQL*Net roundtrips to/from client
0 sorts (memory)
0 sorts (disk)
0 rows processed
优化方法2:
耗时:0.4s
返回:0
--添加hint: /*+ no_unnest */ 目的也是让半连接的sql不展开。与上面改写效果一致。
SELECT D.DAILYAUDITNO, D.TRANSTOACC
FROM PB_DOIC.MM_DAILYREPORT_TD D
WHERE D.REPORTSTATUS = '4'
AND D.TRANSTOACC IN ('00', 'B1')
AND EXISTS (SELECT /*+NO_UNNEST*/1
FROM PB_DOIC.MM_DAILYREPORT_DETAIL_TD
WHERE DAILYAUDITNO = D.DAILYAUDITNO
AND BUSINESSONE || BUSINESSTWO NOT IN
('604988', '605988', '606988', '607988')
AND BUSINESSTWO != '991')
AND NOT EXISTS
(SELECT 1
FROM PB_DOIC.MM_DAILYREPORT_DETAIL_TD E
WHERE E.DAILYAUDITNO = D.DAILYAUDITNO
AND E.BUSINESSONE || E.BUSINESSTWO NOT IN
('604988', '605988', '606988', '607988')
AND E.BUSINESSTWO != '991'
AND NOT EXISTS
(SELECT 1
FROM PB_DOIC.MM_VOUCHERMODULE_TC V
WHERE V.BUSINESSTYPE = E.BUSINESSONE || E.BUSINESSTWO
AND V.MODULETYPE = '1'
AND V.MODULESTATUS = 0))
FOR UPDATE OF D.TRANSTOACC NOWAIT
Execution Plan
----------------------------------------------------------
Plan hash value: 991259826
-----------------------------------------------------------------------------------------------------
| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |
-----------------------------------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | 1 | 49 | 336K (1)| 01:07:15 |
| 1 | FOR UPDATE | | | | | |
|* 2 | FILTER | | | | | |
|* 3 | TABLE ACCESS FULL | MM_DAILYREPORT_TD | 22372 | 1070K| 2632 (2)| 00:00:32 |
|* 4 | INDEX RANGE SCAN | IDX_MM_DAILYREPORT_DETAIL_TD | 1 | 67 | 7 (0)| 00:00:01 |
|* 5 | INDEX RANGE SCAN | IDX_MM_DAILYREPORT_DETAIL_TD | 1 | 67 | 7 (0)| 00:00:01 |
|* 6 | INDEX RANGE SCAN| PK_MM_VOUCHERMODULE_TC | 1 | 15 | 2 (0)| 00:00:01 |
-----------------------------------------------------------------------------------------------------
Predicate Information (identified by operation id):
---------------------------------------------------
2 - filter( EXISTS (SELECT /*+ NO_UNNEST */ 0 FROM "PB_DOIC"."MM_DAILYREPORT_DETAIL_TD"
"MM_DAILYREPORT_DETAIL_TD" WHERE "DAILYAUDITNO"=:B1 AND
"BUSINESSONE"||"BUSINESSTWO"<>'604988' AND "BUSINESSONE"||"BUSINESSTWO"<>'605988' AND
"BUSINESSONE"||"BUSINESSTWO"<>'606988' AND "BUSINESSONE"||"BUSINESSTWO"<>'607988' AND
"BUSINESSTWO"<>'991') AND NOT EXISTS (SELECT /*+ */ 0 FROM
"PB_DOIC"."MM_DAILYREPORT_DETAIL_TD" "SYS_ALIAS_2" WHERE "E"."DAILYAUDITNO"=:B2 AND
"E"."BUSINESSONE"||"E"."BUSINESSTWO"<>'604988' AND
"E"."BUSINESSONE"||"E"."BUSINESSTWO"<>'605988' AND
"E"."BUSINESSONE"||"E"."BUSINESSTWO"<>'606988' AND
"E"."BUSINESSONE"||"E"."BUSINESSTWO"<>'607988' AND "E"."BUSINESSTWO"<>'991' AND NOT EXISTS
(SELECT /*+ */ 0 FROM "PB_DOIC"."MM_VOUCHERMODULE_TC" "V" WHERE "V"."BUSINESSTYPE"=:B3||:B4
AND "V"."MODULETYPE"='1' AND "V"."MODULESTATUS"=0)))
3 - filter(("D"."TRANSTOACC"='00' OR "D"."TRANSTOACC"='B1') AND "D"."REPORTSTATUS"='4')
4 - access("DAILYAUDITNO"=:B1)
filter("BUSINESSONE"||"BUSINESSTWO"<>'604988' AND
"BUSINESSONE"||"BUSINESSTWO"<>'605988' AND "BUSINESSONE"||"BUSINESSTWO"<>'606988' AND
"BUSINESSONE"||"BUSINESSTWO"<>'607988' AND "BUSINESSTWO"<>'991')
5 - access("E"."DAILYAUDITNO"=:B1)
filter("E"."BUSINESSONE"||"E"."BUSINESSTWO"<>'604988' AND
"E"."BUSINESSONE"||"E"."BUSINESSTWO"<>'605988' AND
"E"."BUSINESSONE"||"E"."BUSINESSTWO"<>'606988' AND
"E"."BUSINESSONE"||"E"."BUSINESSTWO"<>'607988' AND "E"."BUSINESSTWO"<>'991' AND NOT EXISTS
(SELECT /*+ */ 0 FROM "PB_DOIC"."MM_VOUCHERMODULE_TC" "V" WHERE "V"."BUSINESSTYPE"=:B1||:B2
AND "V"."MODULETYPE"='1' AND "V"."MODULESTATUS"=0))
6 - access("V"."MODULETYPE"='1' AND "V"."BUSINESSTYPE"=:B1||:B2 AND "V"."MODULESTATUS"=0)
filter("V"."MODULESTATUS"=0)
Statistics
----------------------------------------------------------
1 recursive calls
0 db block gets
105048 consistent gets
0 physical reads
0 redo size
397 bytes sent via SQL*Net to client
481 bytes received via SQL*Net from client
1 SQL*Net roundtrips to/from client
0 sorts (memory)
0 sorts (disk)
0 rows processed
优化方法3:
耗时:0.4s
返回:0
添加hint:/*+ nl_sj */,目的让SQL走semi join
SELECT D.DAILYAUDITNO, D.TRANSTOACC
FROM PB_DOIC.MM_DAILYREPORT_TD D
WHERE D.REPORTSTATUS = '4'
AND D.TRANSTOACC IN ('00', 'B1')
AND EXISTS (SELECT /*+nl_sj*/ 1
FROM PB_DOIC.MM_DAILYREPORT_DETAIL_TD
WHERE DAILYAUDITNO = D.DAILYAUDITNO
AND BUSINESSONE || BUSINESSTWO NOT IN
('604988', '605988', '606988', '607988')
AND BUSINESSTWO != '991')
AND NOT EXISTS
(SELECT 1
FROM PB_DOIC.MM_DAILYREPORT_DETAIL_TD E
WHERE E.DAILYAUDITNO = D.DAILYAUDITNO
AND E.BUSINESSONE || E.BUSINESSTWO NOT IN
('604988', '605988', '606988', '607988')
AND E.BUSINESSTWO != '991'
AND NOT EXISTS
(SELECT 1
FROM PB_DOIC.MM_VOUCHERMODULE_TC V
WHERE V.BUSINESSTYPE = E.BUSINESSONE || E.BUSINESSTWO
AND V.MODULETYPE = '1'
AND V.MODULESTATUS = 0))
FOR UPDATE OF D.TRANSTOACC NOWAIT
Execution Plan
----------------------------------------------------------
Plan hash value: 2686500646
-----------------------------------------------------------------------------------------------------
| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |
-----------------------------------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | 34 | 3944 | 137K (1)| 00:27:29 |
| 1 | FOR UPDATE | | | | | |
|* 2 | FILTER | | | | | |
| 3 | NESTED LOOPS SEMI | | 34 | 3944 | 137K (1)| 00:27:27 |
|* 4 | TABLE ACCESS FULL| MM_DAILYREPORT_TD | 22372 | 1070K| 2632 (2)| 00:00:32 |
|* 5 | INDEX RANGE SCAN | IDX_MM_DAILYREPORT_DETAIL_TD | 1 | 67 | 6 (0)| 00:00:01 |
|* 6 | INDEX RANGE SCAN | IDX_MM_DAILYREPORT_DETAIL_TD | 1 | 67 | 7 (0)| 00:00:01 |
|* 7 | INDEX RANGE SCAN | PK_MM_VOUCHERMODULE_TC | 1 | 15 | 2 (0)| 00:00:01 |
-----------------------------------------------------------------------------------------------------
Predicate Information (identified by operation id):
---------------------------------------------------
2 - filter( NOT EXISTS (SELECT /*+ */ 0 FROM "PB_DOIC"."MM_DAILYREPORT_DETAIL_TD"
"SYS_ALIAS_2" WHERE "E"."DAILYAUDITNO"=:B1 AND
"E"."BUSINESSONE"||"E"."BUSINESSTWO"<>'604988' AND
"E"."BUSINESSONE"||"E"."BUSINESSTWO"<>'605988' AND
"E"."BUSINESSONE"||"E"."BUSINESSTWO"<>'606988' AND
"E"."BUSINESSONE"||"E"."BUSINESSTWO"<>'607988' AND "E"."BUSINESSTWO"<>'991' AND NOT EXISTS
(SELECT /*+ */ 0 FROM "PB_DOIC"."MM_VOUCHERMODULE_TC" "V" WHERE "V"."BUSINESSTYPE"=:B2||:B3
AND "V"."MODULETYPE"='1' AND "V"."MODULESTATUS"=0)))
4 - filter(("D"."TRANSTOACC"='00' OR "D"."TRANSTOACC"='B1') AND "D"."REPORTSTATUS"='4')
5 - access("DAILYAUDITNO"="D"."DAILYAUDITNO")
filter("BUSINESSONE"||"BUSINESSTWO"<>'604988' AND
"BUSINESSONE"||"BUSINESSTWO"<>'605988' AND "BUSINESSONE"||"BUSINESSTWO"<>'606988' AND
"BUSINESSONE"||"BUSINESSTWO"<>'607988' AND "BUSINESSTWO"<>'991')
6 - access("E"."DAILYAUDITNO"=:B1)
filter("E"."BUSINESSONE"||"E"."BUSINESSTWO"<>'604988' AND
"E"."BUSINESSONE"||"E"."BUSINESSTWO"<>'605988' AND
"E"."BUSINESSONE"||"E"."BUSINESSTWO"<>'606988' AND
"E"."BUSINESSONE"||"E"."BUSINESSTWO"<>'607988' AND "E"."BUSINESSTWO"<>'991' AND NOT EXISTS
(SELECT /*+ */ 0 FROM "PB_DOIC"."MM_VOUCHERMODULE_TC" "V" WHERE "V"."BUSINESSTYPE"=:B1||:B2
AND "V"."MODULETYPE"='1' AND "V"."MODULESTATUS"=0))
7 - access("V"."MODULETYPE"='1' AND "V"."BUSINESSTYPE"=:B1||:B2 AND "V"."MODULESTATUS"=0)
filter("V"."MODULESTATUS"=0)
Statistics
----------------------------------------------------------
2114 recursive calls
0 db block gets
83115 consistent gets
1341 physical reads
0 redo size
397 bytes sent via SQL*Net to client
481 bytes received via SQL*Net from client
1 SQL*Net roundtrips to/from client
77 sorts (memory)
0 sorts (disk)
0 rows processed
处理半连接SQL自动改写内连接SQL一例的更多相关文章
- Sql server中内连接语句
数据库中学生表和课程表如下: 内连接sql语句: select a.studentName,a.studentAge,b.courseName from student a inner join co ...
- SQL Server中内连接和外连接的区别
SQL Server中内连接和外连接的区别 假设一个数据库中有两张表,一张是学生表StudentInfo,一张是班级表ClassInfo,两张表之间用ClassId字段进行关联. 如果用内连接,正常的 ...
- 你真的会玩SQL吗?内连接、外连接
原文:你真的会玩SQL吗?内连接.外连接 大多数人一般写多表查询会这样写select * from tbA ,tbB 没有用到JOIN关键字,太Low了,官网标准建议是用JOIN明确表间的关系,下面 ...
- SQL中的内连接与外连接
关于关系代数连接运算的介绍请查看下面链接 http://www.cnblogs.com/xidongyu/articles/5980407.html 连接运算格式 链接运算由两部分构成:连接类型和连接 ...
- Sql中的内连接,左连接以及右连接区别
转自:http://pangaoyuan.javaeye.com/blog/713177 有两个表A和表B. 表A结构如下: Aid:int:标识种子,主键,自增ID Aname:varchar 数据 ...
- 优化子查询sql语句为内连接
背景: 希望提高查询的效率,从sql语句中频繁出现的子查询入手. 数据表如下:Student表中的CityCode对应于City表中的Code. Student表: ...
- SQL 交叉连接与内连接
交叉连接 ,没有任何限制方式的连接. 叫做交叉连接. 碰到一种SQL 的写法. select * from t1,t2 . 这其实是交叉连接 . t1 是三条 , t2 是两条. ...
- SQL中的内连接外连接和交叉连接是什么意思?
内连接又分为等值连接.自然连接和不等连接三种. 外连接分为左外连接(LEFT OUTER JOIN或LEFT JOIN).右外连接(RIGHT OUTER JOIN或RIGHT JOIN)和全外连接( ...
- 清晰讲解SQL语句中的内连接,通用于Mysql和Oracle,全是干货哦
本文章目的:力求清晰明了讲解SQL语句的内连接的各种应用,没有深奥的理解! 前奏:这篇文章和下篇文章会将内连接和外连接讲解清楚SQL语句的多表查询常用的有以下几种:两表联合查询(1)内连接(2)外连接 ...
随机推荐
- 在selenium中一些相对常用的JavaScript事件
输入框输入: 1.找到输入框的id,然后进行输入操作 ordinal :输入框的id parameter :需要输入的内容 browser.execute_script("document. ...
- Ruby String类
String类 更新: 2017/06/10 更新: 2017/06/23 puts()要空格可以直接不加参数 更新: 2017/08/17 增加rails引入的titleize 更新: 2017/1 ...
- 洛谷 P2754 星际转移问题【最大流】
判无解的方法非常粗暴:快T了还是没有合法方案,就是无解. 然后枚举答案,对于每一天都建一套太空站,s连地球,t连月球,上一天的太空站连向这一天的太空站,流量均为inf.然后对于每个飞船,上一天的停靠站 ...
- jquery的validate的用法
//引入js文件 //jquery 文件 <script src="__PUBLIC__/static/wap/js/jquery.min.js?v=2.1.4">&l ...
- SetViewportOrgEx(视口) 与 SetWindowOrgEx(窗口) 解析
SetViewportOrgEx (hdc,x/2,y/2) 视口中心点设置到窗口中心 获取客户群x和y,x/2,y/2 ,这样中心点就到窗口中间了. SetWindowOrgEx(hdc,-x/2, ...
- _bzoj3224 Tyvj 1728 普通平衡树【Splay】
传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=3224 保存splay模版 一刻不停写了一个小时多一点,幸好一遍过了!(其实带着freopen ...
- C#课程设计
一.问题描述 监视文件和文件夹的变化(FileSystemWatcher 类):选择一个文件夹,单击"开始监视",该文件夹处于监视状态,此时对该文件夹如果进行操作,这些行为将显示出 ...
- E. Dasha and Puzzle 数学题
http://codeforces.com/contest/761/problem/E 给出一颗树,要求在坐标系中用平行于坐标轴的线描绘出来. 要求边不能相交,而且点的坐标唯一. 注意到2^1 + 2 ...
- 里氏替换原则中is和as分别的作用
is 是用于检查对象是否指定类型兼容 if(empls[i] is SE){ ((SE)empls).SayHi(); } as 不用强转可以直接转换 if(empls[i] is SE){ SE s ...
- @ComponentScan、@EnableFeignClients和@MapperScan注解笔记
@ComponentScan:此注解是用来管理容器中的bean,即是管理项目中类的依赖关系, 注意此注解并不创建类的实例: 默认情况下此注解扫描本工程下的所有包, ...