日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

何時Oracle使用綁定變量性能反而更差

瀏覽:50日期:2023-11-14 11:33:24
當我在做培訓時,在解釋綁定變量的好處時,大家都比較輕易理解。但是,對于并不是任何時候綁定變量都是最優的。這一點很多人不是和理解。下面就討論一下在什么時候會出現綁定變量會使性能變差。 掃描成本和OPTIMIZER_INDEX_COST_ADJ 我們知道,在CBO模式下,Oracle會計算各個訪問路徑的代價,采用最小代價的訪問路徑作為語句的執行計劃。而對于索引的訪問代價的計算,需要根據一個系統參數OPTIMIZER_INDEX_COST_ADJ來轉換為與全表掃描代價等價的一個值。這是什么意思呢?我們先稍微解釋一下這個參數:OPTIMIZER_INDEX_COST_ADJ。它的值是一個百分比,默認是100,取值范圍是1~10000。當估算索引掃描代價時,會將索引的原始代價值乘以這個百分比,將換算后的值作為與全表掃描代價比較的值。也就是說,當這個值為100時,計算出的索引掃描代價就是它的原始代價: COST_COM = COST_ORG * OPTIMIZER_INDEX_COST_ADJ/100看以下例子: SQL> create table T_PEEKING (a NUMBER, b char(1), c char(2000)); Table created. SQL>SQL> create index T_PEEKING_IDX1 on T_PEEKING(b); Index created. SQL> begin 2 for i in 1..1000 loop 3 insert into T_PEEKING values (i, 'A', i); 4 end loop; 5 6 insert into T_PEEKING values (1001, 'B', 1001); 7 insert into T_PEEKING values (1002, 'B', 1002); 8 insert into T_PEEKING values (1003, 'C', 1003); 9 10 commit; 11 end; 12 / PL/SQL procedure sUCcessfully completed.注重,我們給索引字段B插入的值中只有3個distinct值,記錄數是1003,它的集的勢很高(1003/3)=334。 SQL>SQL> analyze table T_PEEKING compute statistics for table for all indexes for all indexed columns; Table analyzed. SQL>我們看下索引掃描的代價是多少: SQL> show parameter OPTIMIZER_INDEX_COST_ADJ NAME TYPEVALUE------------------------------------ ----------- ------optimizer_index_cost_adj integer 100 SQL> delete from plan_table; 0 rows deleted. SQL> SQL> eXPlain plan for select /*+index(a T_PEEKING_IDX1)*/ * from T_PEEKING a where b = :V; Explained. SQL> select lpad(' ', 2*(level-1))operation' 'options' ' 2 object_name' 'decode(id, 0, 'Cost='position) 'Query 3 Plan_Table' 4 from plan_table 5 start with id = 0 6 connect by prior id = parent_id 7 ; QueryPlan_Table-----------------------------------------------------SELECT STATEMENT Cost=113 TABLE Access BY INDEX ROWID T_PEEKING INDEX RANGE SCAN T_PEEKING_IDX1 SQL>再看全表掃描的代價是多少: SQL> delete from plan_table; 3 rows deleted. SQL>SQL> explain plan for select /*+full(a)*/ * from T_PEEKING a where b = :V; Explained. SQL>SQL> select lpad(' ', 2*(level-1))operation' 'options' ' 2 object_name' 'decode(id, 0, 'Cost='position) 'Query 3 Plan_Table' 4 from plan_table 5 start with id = 0 6 connect by prior id = parent_id 7 ; QueryPlan_Table----------------------------------------------------SELECT STATEMENT Cost=75 TABLE ACCESS FULL T_PEEKING SQL>這時,我們可以計算得出讓優化器使用索引(無提示強制)的OPTIMIZER_INDEX_COST_ADJ值應該< ROUND(COST_FTS/COST_IDX*100) = ROUND(75/113*100) = 66,而大于66則會使用全表掃描: SQL> alter system set OPTIMIZER_INDEX_COST_ADJ=67; System altered. SQL>SQL> delete from plan_table; 2 rows deleted. SQL>SQL> explain plan for select * from T_PEEKING a where b = :V; Explained. SQL>SQL> select lpad(' ', 2*(level-1))operation' 'options' ' 2 object_name' 'decode(id, 0, 'Cost='position) 'Query 3 Plan_Table' 4 from plan_table 5 start with id = 0 6 connect by prior id = parent_id; QueryPlan_Table-----------------------------------------------------------------SELECT STATEMENT Cost=75 TABLE ACCESS FULL T_PEEKING SQL>SQL>SQL> alter system set OPTIMIZER_INDEX_COST_ADJ=66; System altered. SQL>SQL> delete from plan_table; 2 rows deleted. SQL>SQL> explain plan for select * from T_PEEKING a where b = :V; Explained. SQL>SQL> select lpad(' ', 2*(level-1))operation' 'options' ' 2 object_name' 'decode(id, 0, 'Cost='position) 'Query 3 Plan_Table' 4 from plan_table 5 start with id = 0 6 connect by prior id = parent_id; QueryPlan_Table---------------------------------------------------------SELECT STATEMENT Cost=75 TABLE ACCESS BY INDEX ROWID T_PEEKING INDEX RANGE SCAN T_PEEKING_IDX1可以看出,在使用綁定變量時,參數OPTIMIZER_INDEX_COST_ADJ對于是否選擇索引會有重要的影響。這里我們暫且不討論索引掃描的原始成本是如何計算得出的。但是有一點很重要,在使用綁定變量時,計算出的成本是平均成本。在我們上面的例子中,字段B的值只有3個:'A'、'B'、'C',其中A最多,1003行中有1000行。因此,在索引上掃描值為A記錄的成本為1000/1003 * 索引全掃描成本 ≈索引全掃描成本,我們看下它的成本是多少: SQL> alter system set OPTIMIZER_INDEX_COST_ADJ=100; System altered. SQL>SQL> delete from plan_table; 2 rows deleted. SQL>SQL> explain plan for select /*+index(a T_PEEKING_IDX1)*/* from T_PEEKING a where b = 'A'; Explained. SQL>SQL> select lpad(' ', 2*(level-1))operation' 'options' ' 2 object_name' 'decode(id, 0, 'Cost='position) 'Query 3 Plan_Table' 4 from plan_table 5 start with id = 0 6 connect by prior id = parent_id; QueryPlan_Table--------------------------------------------------------------SELECT STATEMENT Cost=336 TABLE ACCESS BY INDEX ROWID T_PEEKING INDEX RANGE SCAN T_PEEKING_IDX1可以看到,它的成本是336。因此索引的平均成本是(336 * 1003/1000) / 3 ≈ 113,也就是使用綁定變量使的成本。而掃描其它兩個值'B'和'A'時代價就非常小。 SQL> alter system set OPTIMIZER_INDEX_COST_ADJ=100; System altered. SQL>SQL> delete from plan_table; 3 rows deleted. SQL>SQL> explain plan for select /*+index(a T_PEEKING_IDX1)*/* from T_PEEKING a where b = 'B'; Explained. SQL>SQL> select lpad(' ', 2*(level-1))operation' 'options' ' 2 object_name' 'decode(id, 0, 'Cost='position) 'Query 3 Plan_Table' 4 from plan_table 5 start with id = 0 6 connect by prior id = parent_id; QueryPlan_Table---------------------------------------------------------------SELECT STATEMENT Cost=2 TABLE ACCESS BY INDEX ROWID T_PEEKING INDEX RANGE SCAN T_PEEKING_IDX1因為計算的成本是平均成本(相對實際掃描某個值的成本,平均成本更接近全表掃描成本),因此在創建查詢計劃時,使用綁定變量將更加輕易受到參數OPTIMIZER_INDEX_COST_ADJ影響,非凡是上面的這種情況(即索引字段的集的勢非常高時)下,平均代價與實際掃描某個值代價相差非常遠。這種情況下,OPTIMIZER_INDEX_COST_ADJ對不使用綁定變量查詢影響就非常小(因為索引代價不是比全表掃描成本大很多就是小很多),不管掃描哪個值,不使用綁定變量將更加輕易選擇到合理的查詢計劃。 綁定變量窺視 在了解了參數OPTIMIZER_INDEX_COST_ADJ的作用后。再了解一個對查詢計劃,非凡是使用綁定變量時會產生重大影響的特性:綁定變量窺視(Bind Variables Peeking)。 綁定變量窺視是9i以后的一個新特性。它使CBO優化器在計算訪問代價時,將綁定變量傳入的值考慮進去,從而計算出更合理的成本(否則,將會計算平均成本)。看下面例子: SQL> conn sys/sys as sysdbaConnected.SQL>SQL> alter system set OPTIMIZER_INDEX_COST_ADJ=60; System altered. SQL> analyze table T_PEEKING compute statistics for table for all indexes for all indexed columns; Table analyzed. SQL>SQL> set autot traceSQL>SQL> alter session set sql_trace = true; Session altered. SQL>SQL> var v char(1)SQL>SQL> exec :v := 'A'; PL/SQL procedure successfully completed. SQL>SQL> select * from T_PEEKING a where b = :V; 1000 rows selected. SQL>SQL> alter session set sql_trace = false; Session altered.用Tkprof處理生成的trace文件。因為在存在綁定變量窺視時,autotrace或者explain plan可能不會顯示正確的查詢計劃,需要Tkprof來處理sql trace。 tkprof fuyuncat_ora_5352.trc aaa.txt此時OPTIMIZER_INDEX_COST_ADJ是60,根據上面的結論,似乎查詢計劃應該選擇掃描索引。但是,這里給綁定變量賦了值'A',這時,優化器會“窺視”到這個值,并且在計算掃描成本時按照這個值的成本來計算。因此,得出的查詢計劃是全表掃描,而不是掃描索引,靠Tkprof分析的結果: select * from T_PEEKING a where b = :V call count cpu elapsed disk query currentrows------- ------ -------- ---------- ---------- ---------- ---------- ----------Parse1 0.00 0.00000 0Execute 1 0.00 0.00000 0Fetch 68 0.01 0.07040601000------- ------ -------- ---------- ---------- ---------- ---------- ----------total 70 0.01 0.08040601000 Misses in library cache during parse: 1Optimizer mode: CHOOSEParsing user id: SYS Rows Row Source Operation------- --------------------------------------------------- 1000 TABLE ACCESS FULL T_PEEKING (cr=406 pr=0 pw=0 time=5052 us)但是,綁定變量窺視對一條語句只會使用一次。就是說,在第一次解析語句時,將綁定變量值考慮進去計算成本生成查詢計劃。以后在執行該語句時都采用這個查詢計劃,而不再考慮以后綁定變量的值是什么了。 SQL> conn sys/sys as sysdbaConnected.SQL>SQL>SQL> set autot traceSQL>SQL> alter session set sql_trace = true; Session altered. SQL>SQL> var v char(1)SQL>SQL> exec :v := 'B'; PL/SQL procedure successfully completed. SQL>SQL> select * from T_PEEKING a where b = :V; 1000 rows selected. SQL>SQL> alter session set sql_trace = false; Session altered.再用Tkprof分析生成的trace文件,看到盡管這里的值是'B',選擇索引掃描會更優,但分析結果中查詢計劃還是使用全表掃描: select * from T_PEEKING a where b = :V call count cpu elapsed disk query currentrows------- ------ -------- ---------- ---------- ---------- ---------- ----------Parse1 0.00 0.00000 0Execute 1 0.00 0.00000 0Fetch2 0.00 0.0003400 2------- ------ -------- ---------- ---------- ---------- ---------- ----------total4 0.00 0.0003400 2 Misses in library cache during parse: 0Optimizer mode: CHOOSEParsing user id: SYS Rows Row Source Operation------- --------------------------------------------------- 2 TABLE ACCESS FULL T_PEEKING (cr=340 pr=0 pw=0 time=1005 us)因此,這種情況下使用綁定變量也會導致無法選擇最優的查詢計劃。 綜上所述,我們可以得出一個結論:在對建有索引的字段(包括字段集),且字段(集)的集的勢非常大時,使用綁定變量可能會導致查詢計劃錯誤,因而會使查詢效率非常低。
標簽: Oracle 數據庫
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产美女高潮在线观看| 亚洲高清激情| 欧美一级二级视频| 国产精品22p| 不卡av一区二区| 欧美中文高清| 青青久久av| 婷婷视频一区二区三区| 久久av国产紧身裤| 一区在线视频观看| 久久激情av| 久久蜜桃精品| 国产欧美一级| 欧美日韩国产免费观看 | 婷婷久久免费视频| 麻豆视频在线观看免费网站黄| 综合视频一区| 久久一级电影| 荡女精品导航| 日韩av不卡在线观看| 国产一区调教| 三级欧美韩日大片在线看| 国产日本久久| 99久久视频| 国产精品久久| 99亚洲视频| 黑森林国产精品av| 99视频+国产日韩欧美| 老牛国内精品亚洲成av人片| 国产欧美日本| 久久精品123| 日韩高清一区在线| 亚洲视频综合| 国产精品**亚洲精品| 日韩专区一卡二卡| 天海翼亚洲一区二区三区| 久久国产婷婷国产香蕉| 国产视频一区三区| 中文在线中文资源| 国产一区二区三区天码| 日韩精品一页| 亚洲麻豆一区| 日韩午夜精品| 久久久久久久久久久妇女| 日本aⅴ亚洲精品中文乱码 | 欧美日韩一区自拍| 欧美亚洲国产激情| 91偷拍一区二区三区精品| 久久国产生活片100| 久久成人国产| 亚洲欧洲一区| 成人羞羞视频播放网站| 激情久久一区二区| 亚洲综合电影| 亚洲精品一区二区在线看| 91精品一区国产高清在线gif| 伊人久久亚洲热| а√天堂8资源中文在线| 国产欧美高清视频在线| 国产亚洲一区二区手机在线观看 | 亚洲少妇一区| 国产欧美一区二区色老头| 精品国产鲁一鲁****| 国产欧美一区| 伊人网在线播放| 水蜜桃精品av一区二区| 精品一区二区三区亚洲 | 国产精品亚洲人成在99www| 麻豆视频在线看| 欧美 日韩 国产精品免费观看| 国产日本亚洲| 国产精品天堂蜜av在线播放| 亚洲精品午夜av福利久久蜜桃| 日韩三级精品| 欧美午夜精品一区二区三区电影| 午夜国产精品视频| 久久国产精品毛片| 日韩三区免费| 日本免费新一区视频| 国产一区二区三区不卡av| 中文字幕在线官网| 亚洲精品进入| 亚洲欧美视频一区二区三区| 欧美国产亚洲精品| 久久视频精品| 日韩毛片一区| 欧美亚洲激情| 日韩av中文字幕一区二区| 日韩av二区| 免费人成网站在线观看欧美高清| 亚洲精品1区2区| 亚洲网址在线观看| 麻豆网站免费在线观看| 麻豆久久久久久| 深夜日韩欧美| 日韩欧美一区二区三区免费看| 国产精品va| 99国产精品视频免费观看一公开| 在线免费观看亚洲| 国产精品成人国产| 欧美~级网站不卡| 欧美日韩一区二区高清| 欧美日韩中文| 一区二区三区四区精品视频| 2023国产精品久久久精品双| 亚洲天堂资源| 日韩av二区| 精品国产亚洲一区二区三区大结局| 日韩黄色免费网站| 亚洲免费福利一区| 国产盗摄——sm在线视频| 日韩精选在线| 视频一区在线视频| 欧美日韩中文一区二区| 精品久久在线| 大香伊人久久精品一区二区 | 久久国产麻豆精品| 九九久久电影| 国语对白精品一区二区| 欧美成人精品一级| 青草国产精品| 国产精区一区二区| 国产亚洲午夜| 欧美 日韩 国产一区二区在线视频| 欧美中文一区二区| 自拍日韩欧美| 伊人精品久久| 欧美一级一区| 国产日韩欧美中文在线| 免费在线观看一区二区三区| 国产suv精品一区二区四区视频 | 97se综合| 日韩精品视频在线看| 亚洲男女av一区二区| 日韩欧美国产精品综合嫩v| 色婷婷色综合| 成人精品天堂一区二区三区| 久久精品欧美一区| 伊人影院久久| 亚洲美女91| 国产日产一区| 国产成人免费av一区二区午夜| 桃色一区二区| 欧美.日韩.国产.一区.二区| 免费视频一区二区| 国产精品综合色区在线观看| 欧美一区=区三区| 日本aⅴ免费视频一区二区三区| 欧美日韩1区2区3区| 久久福利毛片| 国产伦精品一区二区三区在线播放 | 国产精品亚洲综合色区韩国| 7m精品国产导航在线| 国产66精品| 免费久久精品视频| 香蕉成人av| 日韩有吗在线观看| 成人精品中文字幕| 日本国产亚洲| 一区在线视频观看| 成人自拍av| 91久久黄色| 国产传媒在线观看| 麻豆精品在线观看| 欧美中文日韩| 性欧美xxxx免费岛国不卡电影| 中文字幕在线视频网站| 久久精品av| 国产精品密蕾丝视频下载| 亚洲精品成a人ⅴ香蕉片| 91精品美女| 黑人精品一区| 91久久午夜| 日本午夜精品一区二区三区电影| 国产精品久久久久久模特| 久久久一本精品| 欧美日韩一区二区三区视频播放| 欧美专区一区二区三区| 国产欧美视频在线| 国产不卡精品在线| 精品视频一区二区三区在线观看 | 久久国产成人午夜av影院宅| 激情婷婷综合| 国内精品麻豆美女在线播放视频| 蜜桃久久精品一区二区| 欧洲精品一区二区三区| 久久久久97| 国产经典一区| 91在线成人| 综合激情视频| 在线精品福利| 日韩国产欧美三级| 日韩精品免费视频一区二区三区| 日韩动漫一区| 国产成年精品| 精品国产一区二区三区噜噜噜| 美女精品视频在线| 久久av一区二区三区| 亚洲第一区色| 亚洲成人不卡|