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

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

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

瀏覽:47日期: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久久,三上悠亚国产精品一区二区三区
国产精品极品在线观看| 日韩欧美美女在线观看| 日韩中文在线播放| 九一国产精品| 日韩av片子| av资源亚洲| 亚洲精品动态| 国产伦精品一区二区三区在线播放| 欧美a一区二区| 视频一区在线播放| 国产福利电影在线播放| 日本成人在线不卡视频| 日本不卡免费高清视频在线| 快播电影网址老女人久久| 美女视频一区在线观看| 欧美亚洲三级| 狠狠久久伊人中文字幕| 尤物精品在线| 美女免费视频一区| 巨乳诱惑日韩免费av| 久久夜色精品| 日韩激情中文字幕| 日韩美女国产精品| 国产精品嫩模av在线| 久久影视三级福利片| 欧美激情另类| 婷婷综合激情| 亚洲另类黄色| 国产成人a视频高清在线观看| 国产aⅴ精品一区二区四区| 国产精品国产一区| 五月精品视频| 日韩国产欧美视频| 国内精品亚洲| 亚洲国产专区校园欧美| 日韩制服丝袜先锋影音| 国产伦理久久久久久妇女| 久久97视频| 久久精品成人| 一区二区国产精品| 国产精品视频一区二区三区四蜜臂| 麻豆中文一区二区| 国产一区二区三区自拍| 日日摸夜夜添夜夜添国产精品| 欧美aⅴ一区二区三区视频| 日韩综合精品| 亚洲精品无播放器在线播放| 精品一区二区三区四区五区| 久久蜜桃av| а√天堂8资源在线| 成人在线视频中文字幕| 国产精品久久久久毛片大屁完整版| 欧美91精品| 秋霞国产精品| 亚洲大全视频| 日韩一二三区在线观看| 一区二区亚洲精品| 99香蕉国产精品偷在线观看| 九九在线精品| 中文字幕一区久| 欧美亚洲国产激情| 亚洲欧美日韩在线观看a三区| 视频精品一区| 亚洲综合色婷婷在线观看| 国产综合精品| 国产精品丝袜xxxxxxx| 日韩中文字幕一区二区高清99| 国产精品美女午夜爽爽| 五月天久久久| 国产一区精品福利| 亚洲视频二区| 国产精品久久久久av电视剧| 日本不卡视频在线观看 | 精品免费av| 国产精品一在线观看| 精品一二三区| 国产精品一区2区3区| 欧美日韩国产一区二区在线观看| 欧美在线精品一区| 夜夜嗨网站十八久久| 亚洲精品三级| 亚洲午夜91| 免费在线观看一区| 婷婷精品在线| 91久久视频| 亚洲黄色免费av| 国产日韩欧美三级| 视频一区中文字幕国产| 久久国产影院| 精品国产亚洲日本| 亚洲人成亚洲精品| 在线国产一区| 中文一区一区三区高中清不卡免费| 日本欧美一区二区在线观看| 狠狠干综合网| 成人日韩精品| 精品视频一区二区三区在线观看| 婷婷综合电影| 久久午夜精品| 久久久久午夜电影| 裤袜国产欧美精品一区| 国产精品美女在线观看直播| 亚洲人成网77777色在线播放 | 日韩高清电影一区| 亚洲深夜av| 91精品推荐| 欧美日韩国产观看视频| 免费一级欧美片在线观看网站| 亚州精品视频| 亚洲一区二区三区高清不卡| 久久九九电影| 999久久久亚洲| 精品视频在线一区二区在线| 国产精品17p| 乱人伦精品视频在线观看| 鲁大师精品99久久久| 精品国产一区二区三区噜噜噜| 高潮久久久久久久久久久久久久| 国产欧美日韩影院| 久久a爱视频| 成人在线视频区| 日韩欧美视频专区| 国产女优一区| 国产调教精品| 精品久久网站| 国产欧美一区二区三区精品酒店| 久久男人av资源站| 91一区二区三区四区| 国产高清亚洲| 国产区精品区| 亚洲欧美日韩高清在线| 免费视频国产一区| 欧美日韩国产一区二区三区不卡| 青青久久av| 宅男在线一区| 黑丝一区二区三区| 蜜桃传媒麻豆第一区在线观看| 香蕉视频成人在线观看| 蜜臀久久99精品久久久久宅男 | 樱桃视频成人在线观看| 久久中文欧美| 国产高清不卡| 国产精品第十页| 久久久免费人体| 蜜桃久久久久| 日韩大片免费观看| 亚洲午夜黄色| 快she精品国产999| 综合激情一区| 中文字幕av一区二区三区人| 日韩一区二区三区免费视频| 日韩国产欧美视频| 你懂的亚洲视频| 欧产日产国产精品视频| 91精品二区| 亚洲精品综合| 免费在线亚洲欧美| 日本欧美不卡| 樱桃成人精品视频在线播放| 日韩亚洲精品在线| 日本欧美一区二区| 国产精品手机在线播放| а√天堂8资源在线| 日韩午夜av在线| 在线观看亚洲精品福利片| 欧美亚洲自偷自偷| 正在播放日韩精品| 性欧美精品高清| 国产精品久一| 日韩精品一区二区三区免费观看| 影音先锋国产精品| 国产精品一区二区99| 麻豆精品蜜桃| 亚洲tv在线| 欧美国产美女| 国产精品日本| 卡一卡二国产精品| 欧美日韩视频| 国产日韩一区二区三免费高清| 久久精品国产久精国产| 999久久久91| 国内精品99| 久久午夜影视| 少妇精品在线| 日韩va欧美va亚洲va久久| 亚洲一区二区小说| 欧美特黄a级高清免费大片a级| 激情国产在线| 亚洲午夜91| 亚洲精品一二三区区别| 亚洲日本国产| 91精品福利观看| 另类欧美日韩国产在线| 精品视频免费| 中文字幕在线官网| 九九综合九九| 蜜桃av一区二区在线观看| 免费不卡在线视频| 亚洲小说春色综合另类电影| 美女久久精品|