[20210220]全索引掃描快速索引掃描的邏輯讀.txt
[20210220]全索引掃描快速索引掃描的邏輯讀.txt
--//昨天測試了表掃描邏輯讀問題,今天測試看看全索引掃描快速索引掃描的邏輯讀.
1.環境:
SYS@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> alter system set "_trace_pin_time"=1 scope=spfile;
System altered.
--//重啟資料庫.
SYS@book> @ hide _trace_pin
NAME DESCRIPTION DEFAULT_VALUE SESSION_VALUE SYSTEM_VALUE ISSES ISSYS_MOD
--------------- ------------------------------------ ------------- ------------- ------------ ----- ---------
_trace_pin_time trace how long a current pin is held FALSE 1 1 FALSE FALSE
2.測試INDEX FULL SCAN:
SCOTT@book> alter session set "_serial_direct_read"=never;
Session altered.
SCOTT@book> alter session set statistics_level = all;
Session altered.
SCOTT@book> select count(*) from emp;
COUNT(*)
----------
14
Plan hash value: 2937609675
-------------------------------------------------------------------------------------------------------------
| Id | Operation | Name | Starts | E-Rows | Cost (%CPU)| E-Time | A-Rows | A-Time | Buffers |
-------------------------------------------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | 1 | | 1 (100)| | 1 |00:00:00.01 | 1 |
| 1 | SORT AGGREGATE | | 1 | 1 | | | 1 |00:00:00.01 | 1 |
| 2 | INDEX FULL SCAN| PK_EMP | 1 | 14 | 1 (0)| 00:00:01 | 14 |00:00:00.01 | 1 |
-------------------------------------------------------------------------------------------------------------
--//跟蹤發現如下:
*** 2021-02-20 08:27:27.735
pin qeilwhrp: qeilbk dba 0x100009b:1 time 2720838425
3.測試INDEX FAST FULL SCAN:
SCOTT@book> select /*+ index_ffs(emp) */count(*) from emp;
COUNT(*)
----------
14
Plan hash value: 1006289799
------------------------------------------------------------------------------------------------------------------
| Id | Operation | Name | Starts | E-Rows | Cost (%CPU)| E-Time | A-Rows | A-Time | Buffers |
------------------------------------------------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | 1 | | 2 (100)| | 1 |00:00:00.01 | 3 |
| 1 | SORT AGGREGATE | | 1 | 1 | | | 1 |00:00:00.01 | 3 |
| 2 | INDEX FAST FULL SCAN| PK_EMP | 1 | 14 | 2 (0)| 00:00:01 | 14 |00:00:00.01 | 3 |
------------------------------------------------------------------------------------------------------------------
--//跟蹤發現如下:
*** 2021-02-20 08:28:53.366
pin ktewh26: kteinpscan dba 0x100009a:4 time 2806469226
pin ktewh26: kteinpscan dba 0x100009a:4 time 2806469311
pin kdiwh100: kdircys dba 0x100009b:1 time 2806469343
4.gdb無法跟蹤的問題:
(gdb) b kdircys
Function "kdircys" not defined.
Make breakpoint pending on future shared library load? (y or [n]) y
Breakpoint 1 (kdircys) pending.
(gdb) b qeilbk
Function "qeilbk" not defined.
Make breakpoint pending on future shared library load? (y or [n]) y
Breakpoint 2 (qeilbk) pending.
--//出現Make breakpoint pending on future shared library load?,如果選擇Y.也無法跟蹤到斷點.
5.看看唯一索引的情況:
SCOTT@book> select * from emp where empno=7369;
EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
---------- ---------- --------- ---------- ------------------- ---------- ---------- ----------
7369 SMITH CLERK 7902 1980-12-17 00:00:00 800 20
Plan hash value: 2949544139
--------------------------------------------------------------------------------------------------------------------------------
| Id | Operation | Name | Starts | E-Rows |E-Bytes| Cost (%CPU)| E-Time | A-Rows | A-Time | Buffers |
--------------------------------------------------------------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | 1 | | | 1 (100)| | 1 |00:00:00.01 | 2 |
| 1 | TABLE ACCESS BY INDEX ROWID| EMP | 1 | 1 | 38 | 1 (0)| 00:00:01 | 1 |00:00:00.01 | 2 |
|* 2 | INDEX UNIQUE SCAN | PK_EMP | 1 | 1 | | 0 (0)| | 1 |00:00:00.01 | 1 |
--------------------------------------------------------------------------------------------------------------------------------
--//跟蹤沒有任何資訊.
6.看看rowid探查的情況:
SCOTT@book> select * from emp where rowid='AAAVREAAEAAAACXAAA';
EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
---------- ---------- --------- ---------- ------------------- ---------- ---------- ----------
7369 SMITH CLERK 7902 1980-12-17 00:00:00 800 20
Plan hash value: 1116584662
-----------------------------------------------------------------------------------------------------------------------------
| Id | Operation | Name | Starts | E-Rows |E-Bytes| Cost (%CPU)| E-Time | A-Rows | A-Time | Buffers |
-----------------------------------------------------------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | 1 | | | 1 (100)| | 1 |00:00:00.01 | 1 |
| 1 | TABLE ACCESS BY USER ROWID| EMP | 1 | 1 | 38 | 1 (0)| 00:00:01 | 1 |00:00:00.01 | 1 |
-----------------------------------------------------------------------------------------------------------------------------
*** 2021-02-20 08:37:31.503
pin kdswh05: kdsgrp dba 0x1000097:1 time 3324606823
7.最後看看快速索引掃描的情況.
SCOTT@book> create table t as select * from all_objects;
Table created.
SCOTT@book> create index i_t_owner_obj_name on t (owner,object_name) ;
Index created.
SCOTT@book> @ seg i_t_owner_obj_name
SCOTT@book> @prxx
==============================
SEG_MB : 4
SEG_OWNER : SCOTT
SEG_SEGMENT_NAME : I_T_OWNER_OBJ_NAME
SEG_PARTITION_NAME :
SEG_SEGMENT_TYPE : INDEX
SEG_TABLESPACE_NAME : USERS
BLOCKS : 512
HDRFIL : 4
HDRBLK : 1986
PL/SQL procedure successfully completed.
--//分析略.
SCOTT@book> select count(*) from t;
COUNT(*)
----------
84774
Plan hash value: 1196567590
------------------------------------------------------------------------------------------------------------------------------
| Id | Operation | Name | Starts | E-Rows | Cost (%CPU)| E-Time | A-Rows | A-Time | Buffers |
------------------------------------------------------------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | 1 | | 135 (100)| | 1 |00:00:00.06 | 501 |
| 1 | SORT AGGREGATE | | 1 | 1 | | | 1 |00:00:00.06 | 501 |
| 2 | INDEX FAST FULL SCAN| I_T_OWNER_OBJ_NAME | 1 | 84774 | 135 (0)| 00:00:02 | 84774 |00:00:00.06 | 501 |
------------------------------------------------------------------------------------------------------------------------------
$ grep ^pin /tmp/ab.txt |wc
501 3507 26557
$ grep -n -C1 kteinmap /tmp/ab.txt
2-pin ktewh26: kteinpscan dba 0x10007c2:4 time 148494304
3:pin ktewh27: kteinmap dba 0x10007c2:4 time 148499972
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
4-pin ktewh26: kteinpscan dba 0x10007c2:4 time 148505557
5:pin ktewh27: kteinmap dba 0x10007c2:4 time 148511168
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
6:pin ktewh27: kteinmap dba 0x10007c2:4 time 148516498
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
7-pin kdiwh100: kdircys dba 0x10007c3:1 time 148516571
--
79-pin kdiwh100: kdircys dba 0x1000d97:1 time 148520913
80:pin ktewh27: kteinmap dba 0x10007c2:4 time 148526353
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
81-pin kdiwh100: kdircys dba 0x1000d01:1 time 148526407
--//一共4次,有點與全表掃描不同的是集中在開始要呼叫2次kteinpscan.kteinmap.
--//另外你檢視select /*+ index_ffs(emp) */count(*) from emp;
*** 2021-02-20 08:28:53.366
pin ktewh26: kteinpscan dba 0x100009a:4 time 2806469226
pin ktewh26: kteinpscan dba 0x100009a:4 time 2806469311
pin kdiwh100: kdircys dba 0x100009b:1 time 2806469343
--//猜測這個跟全表掃描類似,如果Auxillary Map僅僅1個Extent時,全索引快速掃描不會將出現kteinmap計入邏輯讀.
--//0x10007c2 = set dba 4,1986 = alter system dump datafile 4 block 1986 = 16779202
SCOTT@book> alter system dump datafile 4 block 1986 ;
System altered.
--//INDEX FAST FULL SCAN類似將索引當作表的全掃描.開始連續2次kteinpscan,kteinmap.
--//轉儲 Auxillary Map部分如下:
Auxillary Map
--------------------------------------------------------
Extent 0 : L1 dba: 0x010007c0 Data dba: 0x010007c3
Extent 1 : L1 dba: 0x010007c0 Data dba: 0x010007c8
Extent 2 : L1 dba: 0x010007d0 Data dba: 0x010007d1
Extent 3 : L1 dba: 0x010007d0 Data dba: 0x010007d8
Extent 4 : L1 dba: 0x010007e0 Data dba: 0x010007e1
Extent 5 : L1 dba: 0x010007e0 Data dba: 0x010007e8
Extent 6 : L1 dba: 0x010007f0 Data dba: 0x010007f1
Extent 7 : L1 dba: 0x010007f0 Data dba: 0x010007f8
Extent 8 : L1 dba: 0x01000d88 Data dba: 0x01000d89
Extent 9 : L1 dba: 0x01000d88 Data dba: 0x01000d90
------------------------------------------------->讀到0x1000d97後出現kteinmap.
Extent 10 : L1 dba: 0x01000d00 Data dba: 0x01000d01
Extent 11 : L1 dba: 0x01000d00 Data dba: 0x01000d08
Extent 12 : L1 dba: 0x01000d10 Data dba: 0x01000d11
Extent 13 : L1 dba: 0x01000d10 Data dba: 0x01000d18
Extent 14 : L1 dba: 0x01000d20 Data dba: 0x01000d21
Extent 15 : L1 dba: 0x01000d20 Data dba: 0x01000d28
Extent 16 : L1 dba: 0x01000e00 Data dba: 0x01000e02
Extent 17 : L1 dba: 0x01000e80 Data dba: 0x01000e82
Extent 18 : L1 dba: 0x01000f00 Data dba: 0x01000f02
--------------------------------------------------------
--//1次呼叫kteinmap讀10個Extent.
8.最後看看索引全掃描的情況.
SCOTT@book> select /*+ INDEX_ASC(t) */ count(*) from t;
COUNT(*)
----------
84774
Plan hash value: 2053645701
-------------------------------------------------------------------------------------------------------------------------
| Id | Operation | Name | Starts | E-Rows | Cost (%CPU)| E-Time | A-Rows | A-Time | Buffers |
-------------------------------------------------------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | 1 | | 495 (100)| | 1 |00:00:00.03 | 494 |
| 1 | SORT AGGREGATE | | 1 | 1 | | | 1 |00:00:00.03 | 494 |
| 2 | INDEX FULL SCAN| I_T_OWNER_OBJ_NAME | 1 | 84774 | 495 (1)| 00:00:06 | 84774 |00:00:00.03 | 494 |
-------------------------------------------------------------------------------------------------------------------------
$ grep ^pin /tmp/ac.txt |wc
492 3444 25585
--//奇怪存在2個差距.索引全掃描是單塊讀,cost有點高.
--//後記:我估計跟索引root節點以及葉子節點cbc採用共享拴鎖模式有關.
$ head /tmp/ac.txt ; echo ;tail /tmp/ac.txt
*** 2021-02-20 09:13:46.572
pin qeilwhnp: qeilbk dba 0x10007c4:1 time 1204708362
pin kdiwh15: kdifxs dba 0x10007c5:1 time 1204708513
pin kdiwh15: kdifxs dba 0x10007c6:1 time 1204708586
pin kdiwh15: kdifxs dba 0x10007c7:1 time 1204708650
pin kdiwh15: kdifxs dba 0x10007c8:1 time 1204708720
pin kdiwh15: kdifxs dba 0x10007c9:1 time 1204708785
pin kdiwh15: kdifxs dba 0x10007ca:1 time 1204708849
pin kdiwh15: kdifxs dba 0x10007cb:1 time 1204708956
pin kdiwh15: kdifxs dba 0x10007cc:1 time 1204709022
pin kdiwh15: kdifxs dba 0x1000f74:1 time 1204741750
pin kdiwh15: kdifxs dba 0x1000f75:1 time 1204741818
pin kdiwh15: kdifxs dba 0x1000f76:1 time 1204741885
pin kdiwh15: kdifxs dba 0x1000f77:1 time 1204741959
pin kdiwh15: kdifxs dba 0x1000f78:1 time 1204742031
pin kdiwh15: kdifxs dba 0x1000f79:1 time 1204742105
pin kdiwh15: kdifxs dba 0x1000f7a:1 time 1204742178
pin kdiwh15: kdifxs dba 0x1000f7b:1 time 1204742250
pin kdiwh15: kdifxs dba 0x1000f7c:1 time 1204742331
pin kdiwh15: kdifxs dba 0x1000f7d:1 time 1204742422
--//掃描葉子節點使用的函式是kdifxs,與快速全索引掃描的函式kdircys不同.
9.gdb跟蹤kdifxs的問題:
--//有點奇怪的是如果跟蹤kdifxs,會發現每取一條記錄呼叫1次kdifxs.
break kdifxs
set pagination off
commands
silent
shell echo -n $( date +"%Y/%m/%d %T.%N : ")
printf "kdifxs 0x%x\n", *($rdi+28)
continue
end
SCOTT@book> select /*+ INDEX_ASC(t) */ count(*) from emp;
COUNT(*)
----------
14
--//跟蹤檔案:
*** 2021-02-20 09:35:56.279
pin qeilwhrp: qeilbk dba 0x100009b:1 time 2534414893
--//gdb
2021/02/20 09:35:56.283527260 :kdifxs 0x100009b
2021/02/20 09:35:56.288943445 :kdifxs 0x100009b
2021/02/20 09:35:56.294140527 :kdifxs 0x100009b
2021/02/20 09:35:56.299311991 :kdifxs 0x100009b
2021/02/20 09:35:56.304559641 :kdifxs 0x100009b
2021/02/20 09:35:56.309751711 :kdifxs 0x100009b
2021/02/20 09:35:56.315070138 :kdifxs 0x100009b
2021/02/20 09:35:56.320309307 :kdifxs 0x100009b
2021/02/20 09:35:56.325567607 :kdifxs 0x100009b
2021/02/20 09:35:56.330755128 :kdifxs 0x100009b
2021/02/20 09:35:56.336053584 :kdifxs 0x100009b
2021/02/20 09:35:56.341249687 :kdifxs 0x100009b
2021/02/20 09:35:56.346460461 :kdifxs 0x100009b
2021/02/20 09:35:56.351713932 :kdifxs 0x100009b
2021/02/20 09:35:56.356859085 :kdifxs 0x100009b
--//一共15行.
--//我修改如下:
set var a=0x0
break kdifxs if *($rdi+28) != a
set pagination off
commands
silent
shell echo -n $( date +"%Y/%m/%d %T.%N : ")
printf " kdifxs 0x%x\n", *($rdi+28)
set var a= *($rdi+28)
continue
end
--//注意這樣不能作為邏輯讀統計.注我不熟悉gdb的調式.
SCOTT@book> set arraysize 2
SCOTT@book> select /*+ INDEX_ASC(t) */ empno from emp;
*** 2021-02-20 10:01:02.141
pin qeilwhrp: qeilbk dba 0x100009b:1 time 4040276637
pin kdiwh16: kdifxs dba 0x100009b:1 time 4040278254
pin kdiwh16: kdifxs dba 0x100009b:1 time 4040279670
pin kdiwh16: kdifxs dba 0x100009b:1 time 4040280965
pin kdiwh16: kdifxs dba 0x100009b:1 time 4040282210
pin kdiwh16: kdifxs dba 0x100009b:1 time 4040283446
pin kdiwh16: kdifxs dba 0x100009b:1 time 4040284689
pin kdiwh16: kdifxs dba 0x100009b:1 time 4040285942
--//邏輯讀8.
--//gdb下僅僅看到1行.
(gdb) c
Continuing.
2021/02/20 10:04:23.791914398 :kdifxs 0x100009b
10.最後看看索引範圍掃描:
SCOTT@book> set arraysize 400
SCOTT@book> select /*+ index(t) */ CREATED from t where owner='SCOTT';
CREATED
-------------------
2013-08-24 12:04:21
...
2017-01-03 11:41:11
22 rows selected.
Plan hash value: 3696261165
--------------------------------------------------------------------------------------------------------------------------------------------
| Id | Operation | Name | Starts | E-Rows |E-Bytes| Cost (%CPU)| E-Time | A-Rows | A-Time | Buffers |
--------------------------------------------------------------------------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | 1 | | | 2237 (100)| | 22 |00:00:00.01 | 18 |
| 1 | TABLE ACCESS BY INDEX ROWID| T | 1 | 2923 | 40922 | 2237 (0)| 00:00:27 | 22 |00:00:00.01 | 18 |
|* 2 | INDEX RANGE SCAN | I_T_OWNER_OBJ_NAME | 1 | 2923 | | 19 (0)| 00:00:01 | 22 |00:00:00.01 | 4 |
--------------------------------------------------------------------------------------------------------------------------------------------
*** 2021-02-20 10:08:47.319
pin qeilwhnp: qeilbk dba 0x1000e8f:1 time 210487381
pin kdswh05: kdsgrp dba 0x100074c:1 time 210487471
pin kdiwh16: kdifxs dba 0x1000e8f:1 time 210487812
pin kdswh05: kdsgrp dba 0x1000755:1 time 210487858
pin kdswh05: kdsgrp dba 0x100074c:1 time 210487892
pin kdswh05: kdsgrp dba 0x1000755:1 time 210487914
pin kdswh05: kdsgrp dba 0x100074c:1 time 210487932
pin kdswh05: kdsgrp dba 0x1000755:1 time 210487951
pin kdswh05: kdsgrp dba 0x100074d:1 time 210487971
pin kdswh05: kdsgrp dba 0x1000755:1 time 210487988
pin kdswh05: kdsgrp dba 0x100074c:1 time 210488006
pin kdswh05: kdsgrp dba 0x1000755:1 time 210488026
pin kdswh05: kdsgrp dba 0x100074c:1 time 210488044
pin kdswh05: kdsgrp dba 0x100074d:1 time 210488069
pin kdswh05: kdsgrp dba 0x100074c:1 time 210488089
pin kdswh05: kdsgrp dba 0x1000755:1 time 210488107
--//邏輯讀16.還是少2個.
--//後記:我估計跟索引root節點以及葉子節點cbc採用共享拴鎖模式有關.
SCOTT@book> alter system reset "_trace_pin_time";
System altered.
--//重啟,不然下面的跟蹤資訊太亂了.
SCOTT@book> @ treedump i_t_owner_obj_name
old 1: select object_id from user_objects where object_name = upper('&&1') and object_type = 'INDEX'
new 1: select object_id from user_objects where object_name = upper('i_t_owner_obj_name') and object_type = 'INDEX'
OBJECT_ID
----------
90544
old 1: alter session set events 'immediate trace name treedump level &m_index_id'
new 1: alter session set events 'immediate trace name treedump level 90544'
Session altered.
----- begin tree dump
branch: 0x10007c3 16779203 (0: nrow: 2, level: 2)
branch: 0x1000efb 16781051 (-1: nrow: 363, level: 1)
--//應該是漏掉這2個塊的邏輯讀.檢索找不到這兩塊的讀操作.
leaf: 0x10007c4 16779204 (-1: nrow: 157 rrow: 157)
leaf: 0x10007c5 16779205 (0: nrow: 159 rrow: 159)
leaf: 0x10007c6 16779206 (1: nrow: 148 rrow: 148)
leaf: 0x10007c7 16779207 (2: nrow: 157 rrow: 157)
leaf: 0x10007c8 16779208 (3: nrow: 154 rrow: 154)
leaf: 0x10007c9 16779209 (4: nrow: 158 rrow: 158)
...
leaf: 0x1000f78 16781176 (122: nrow: 187 rrow: 187)
leaf: 0x1000f79 16781177 (123: nrow: 195 rrow: 195)
leaf: 0x1000f7a 16781178 (124: nrow: 185 rrow: 185)
leaf: 0x1000f7b 16781179 (125: nrow: 227 rrow: 227)
leaf: 0x1000f7c 16781180 (126: nrow: 221 rrow: 221)
leaf: 0x1000f7d 16781181 (127: nrow: 61 rrow: 61)
----- end tree dump
11.總結:
--//測試有點亂,基本想到哪裡做到哪裡.
--//使用"_trace_pin_time"=1探究全表掃描以及快速全索引掃描邏輯讀還是很準確的,索引一些邏輯讀存在一些誤差.
--//kteinmap 呼叫實際上跟全表掃描類似.不知道是為什麼快速全掃描開始出現2次kteinpscan,extents多的話還會出現2次kteinmap.
--//gdb無法跟蹤qeilbk,kdircys, 不知道是為什麼快速全掃描開始出現2次.
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/267265/viewspace-2757859/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- [20190815]索引快速全掃描的成本.txt索引
- 全表掃描和全索引掃描索引
- [20210219]全表掃描邏輯讀問題.txt
- MySQL中的全表掃描和索引樹掃描MySql索引
- 全表掃描和全索引掃描繼續(PG-TiDB)索引TiDB
- 【Oracle】 索引的掃描方式Oracle索引
- AppBoxFuture: 二級索引及索引掃描查詢資料APP索引
- PostgreSQL技術內幕(七)索引掃描SQL索引
- 索引掃描可能不如全表掃描的場景的理解__純粹資料量而言,不涉及CLUSTERING_FACTOR索引
- 掃描器的存在、奧普 掃描器
- AWVS掃描器掃描web漏洞操作Web
- win10系統掃描器提示掃描不到掃描器如何解決Win10
- 掃描器
- 掃描王 for Mac專業圖片掃描工具Mac
- 什麼是漏洞掃描?漏洞掃描功能有哪些?
- [20190221]使用nmap掃描埠的問題.txt
- [20210220]gdb跟蹤邏輯讀2.txt
- 目錄掃描
- 埠掃描器
- python掃描埠Python
- 技術分享 | 為什麼 SELECT 查詢選擇全表掃描,而不走索引?索引
- DAST 黑盒漏洞掃描器 第四篇:掃描效能AST
- 電腦掃描檔案怎麼掃描 win10電腦掃描檔案方法介紹Win10
- oracle是如何進行全表掃描的Oracle
- 京東掃描平臺EOS—JS掃描落地與實踐JS
- SQL Server索引查詢/掃描沒有出現key lookup的案例淺析SQLServer索引
- 【讀書筆記】《PostgreSQL指南-內幕探索》-7.堆內元組和僅索引掃描筆記SQL索引
- 掃描行為分析
- 綜合掃描工具
- 淺談掃描線
- P2032 掃描
- Nydus 映象掃描加速
- sonar(二)掃描配置
- direasch目錄掃描
- Zenmap(埠掃描工具)
- RustScan: 能在3秒內掃描65k個埠的Rust掃描工具Rust
- TWAIN掃描識別控制元件:Web應用程式的掃描器SDKAI控制元件Web
- [20200306]hash join會提前終止掃描嗎.txt