精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

數據庫性能問題總結--屢次發生的Oracle謂詞越界

數據庫 Oracle
近期在客戶現場屢次遇到由于統計信息過舊,導致執行計劃選錯引發的數據庫性能問題,今天做個總結。

 [[392208]]

本文轉載自微信公眾號「數據和云」,作者任艷杰。轉載本文請聯系數據和云公眾號。  

近期在客戶現場屢次遇到由于統計信息過舊,導致執行計劃選錯引發的數據庫性能問題,今天做個總結。

謂詞越界常見發生在 where 謂詞是時間字段的情況,總的來說統計信息記錄的是一個過舊的時間,而 SQL 傳入的時間是一個最新的時間范圍(往往是 <time time1<c<time2)由于統計信息不全,按照 CBO 計算出來的結果集就很小,在多表關聯的情況下,CBO 就會選擇認為的最優的關聯方式,而實際執行時發現不是那么回事,有大量結果集需要掃描,就會爆發 SQL 性能問題。

謂詞越界就是 select 的謂詞的條件不在統計信息 low_value 和 high_value 之間,在實際選擇結果集要大于 CBO 記錄的結果集數量,即實際的 selectivity 偏大,這種情況下 CBO 評估出來的 selectivity 會出現嚴重的偏差,導致 CBO 選錯執行計劃。

測試驗證

下面做一組測試,從執行計劃 cost 看謂詞越界的發生過程,先插入部分數據:

  1. DECLARE 
  2. INT
  3. BEGIN 
  4. i := 78179; 
  5. WHILE(i < 100000) 
  6. LOOP 
  7. i := i + 1; 
  8. INSERT INTO test_obj(object_id) VALUES(i); 
  9. COMMIT
  10. END LOOP; 
  11. END

查看此時的 num_rows:

  1. TEST@PROD1> select count(*) from test_obj; 
  2.   COUNT(*) 
  3. ---------- 
  4.      94283 
  5. TEST@PROD1> select max(object_ID),dump(max(object_id),16) from test_obj; 
  6.   
  7. MAX(OBJECT_ID) DUMP(MAX(OBJECT_ID),16) 
  8. -------------- ---------------------------------------- 
  9.         100000 Typ=2 Len=2: c3,b     
  10. TEST@PROD1> select min(object_ID),dump(min(object_id),16) from test_obj; 
  11.   
  12. MIN(OBJECT_ID   )               DUMP(MIN(OBJECT_ID),16) 
  13. ------------------------------ ---------------------------------------- 
  14.       2                          Typ=2 Len=2: c1,3        --C103 

不收集統計信息,此時統計列統計信息過舊,HIGH_VALUE 依然是原來的值 78179。

  1. TEST@PROD1> select  low_value ,high_value,num_distinct,num_nulls from  DBA_TAB_COL_STATISTICS where table_name='TEST_OBJ' and owner='TEST'
  2.   
  3.                                                                   Distinct     Number 
  4. LOW_VALUE                      HIGH_VALUE                           Values      Nulls 
  5. ------------------------------ ------------------------------ ------------ ---------- 
  6. C103                           C3085250                             72,462(原值)  0 

查詢結果返回 2081 行結果集。

  1. TEST@PROD1> select count(*) from test_obj where object_id between 78200 and 81000; 
  2.   COUNT(*) 
  3. ---------- 
  4.       2801 
  5. 計算公式為: 
  6. selectivity=((VAL2 - VAL1) / (HIGH_VALUE - LOW_VALUE)+2 / NUM_DISTINCT) * null_adjust 
  7. null_adjust=(NUM_ROES - NUM_NULLS) / NUM_ROES 
  8.  
  9. 計算結果為: 
  10. TEST@PROD1>  select round(((81000-78200)/(100000-2)+2/94283)*(94283-0)/94283*94283) from dual;  
  11.   
  12. ROUND(((81000-78200)/(100000-2)+2/94283)*(94283-0)/94283*94283) 
  13. --------------------------------------------------------------- 
  14.                                                            2642 

查看結果集發現 dictionary 值為 1,這明顯是一個錯誤的執行計劃,由于統計信息過舊,已經低于謂詞條件區間(謂詞過界)導致 CBO 低估了查詢成本。

  1. TEST@PROD1>  select count(*) from test_obj where object_id between 78200 and 81000; 
  2.   
  3. Execution Plan 
  4. ---------------------------------------------------------- 
  5. Plan hash value: 2217143630 
  6.   
  7. ------------------------------------------------------------------------------- 
  8. | Id  | Operation          | Name     | Rows  | Bytes | Cost (%CPU)| Time     | 
  9. ------------------------------------------------------------------------------- 
  10. |   0 | SELECT STATEMENT   |          |     1 |     5 |   289   (1)| 00:00:04 | 
  11. |   1 |  SORT AGGREGATE    |          |     1 |     5 |            |          | 
  12. |*  2 |   TABLE ACCESS FULL| TEST_OBJ |     1 |     5 |   289   (1)| 00:00:04 | 
  13. ------------------------------------------------------------------------------- 
  14.   
  15. Predicate Information (identified by operation id): 
  16. --------------------------------------------------- 
  17.   
  18.    2 - filter("OBJECT_ID">=78200 AND "OBJECT_ID"<=81000) 
  19.   
  20.   
  21. Statistics 
  22. ---------------------------------------------------------- 
  23.           1  recursive calls 
  24.           0  db block gets 
  25.        1117  consistent gets 
  26.           0  physical reads 
  27.           0  redo size 
  28.         423  bytes sent via SQL*Net to client 
  29.         419  bytes received via SQL*Net from client 
  30.           2  SQL*Net roundtrips to/from client 
  31.           0  sorts (memory) 
  32.           0  sorts (disk) 
  33.           1  rows processed 

重新收集統計信息再次查看執行計劃。

  1. TEST@PROD1> exec dbms_stats.gather_table_stats('test','test_obj'); 
  2. TEST@PROD1> select  low_value ,high_value,num_distinct,num_nulls from  DBA_TAB_COL_STATISTICS where table_name='TEST_OBJ' and owner='TEST'
  3.   
  4.                                               Distinct     Number 
  5. LOW_VALUE            HIGH_VALUE                 Values      Nulls 
  6. -------------------- -------------------- ------------ ---------- 
  7. C103                 C30B                       94,283          0 

此時統計信息 HIGH_VALUE 已經和最初計算的值相等,Typ=2 Len=2: c3,b。再次查看執行計劃,此時 CBO 已經能夠產生了正確的執行計劃了。

執行計劃為:

  1. TEST@PROD1> select count(*) from test_obj where object_id between 78200 and 81000; 
  2.   
  3. Execution Plan 
  4. ---------------------------------------------------------- 
  5. Plan hash value: 2217143630 
  6.   
  7. ------------------------------------------------------------------------------- 
  8. | Id  | Operation          | Name     | Rows  | Bytes | Cost (%CPU)| Time     | 
  9. ------------------------------------------------------------------------------- 
  10. |   0 | SELECT STATEMENT   |          |     1 |     5 |   314   (1)| 00:00:04 | 
  11. |   1 |  SORT AGGREGATE    |          |     1 |     5 |            |          | 
  12. |*  2 |   TABLE ACCESS FULL| TEST_OBJ |  2642 | 13210 |   314   (1)| 00:00:04 | 
  13. ------------------------------------------------------------------------------- 
  14.   
  15. Predicate Information (identified by operation id): 
  16. --------------------------------------------------- 
  17.   
  18.    2 - filter("OBJECT_ID">=78200 AND "OBJECT_ID"<=81000) 
  19.   
  20.   
  21. Statistics 
  22. ---------------------------------------------------------- 
  23.           0  recursive calls 
  24.           0  db block gets 
  25.        1117  consistent gets 
  26.           0  physical reads 
  27.           0  redo size 
  28.         423  bytes sent via SQL*Net to client 
  29.         419  bytes received via SQL*Net from client 
  30.           2  SQL*Net roundtrips to/from client 
  31.           0  sorts (memory) 
  32.           0  sorts (disk) 
  33.           1  rows processed 

謂詞越界主要發生在大表,按照 Oracle 統計信息收集機制,表的數據變化量達到 10% 以上才會進行統計信息收集,大表不常收集統計信息就容易爆發謂詞越界。

預防方式

可對關鍵表實行按謂詞查詢條件分區,即按天或者按月分區可規避此問題發生。

責任編輯:武曉燕 來源: 數據和云
相關推薦

2023-11-16 17:12:33

數據庫oracle

2010-05-04 17:08:24

Oracle數據庫

2010-06-17 12:59:07

Oracle

2010-04-13 10:32:40

Oracle數據庫編程

2010-04-20 10:41:49

Oracle數據庫

2011-04-12 10:09:33

Oracle數據庫關閉

2011-05-20 10:30:20

ORACLE數據庫性能優化

2011-05-18 09:39:19

Oracle數據庫性能優化

2009-02-01 13:33:13

Oracle數據庫配置

2010-05-07 17:39:02

Oracle數據庫性能

2010-11-15 16:13:24

Oracle數據庫性能

2010-05-10 15:50:39

Oracle數據庫性能

2011-03-28 15:44:45

惠普數據庫Oracle數據庫

2011-06-14 15:11:59

ORACLE

2011-09-02 10:06:51

OracleSqlLoad常用技巧

2010-04-07 09:31:02

Oracle數據庫

2010-04-09 15:08:17

Oracle 數據庫性

2010-12-10 10:17:21

關系型數據庫

2011-03-17 14:09:25

Oracle數據庫字符

2010-04-16 10:18:10

Import性能
點贊
收藏

51CTO技術棧公眾號

都市激情亚洲色图| 成人av电影在线网| 日韩网站在线观看| 欧美xxxx黑人| 345成人影院| 国产精品成人免费在线| 粉嫩高清一区二区三区精品视频 | 免费av一区| 欧美视频在线一区| 国产 欧美 日韩 一区| 欧美成人免费| 国产主播一区二区| 97人人爽人人喊人人模波多| 国产精品成人在线视频| 中文字幕日韩高清在线| 色狠狠桃花综合| 丰满的少妇愉情hd高清果冻传媒| 国产女主播在线写真| 国产高清精品网站| 国产精品视频永久免费播放| 久久精品国产亚洲av高清色欲| 国内成人精品| 亚洲精品成人免费| 亚洲天堂av一区二区三区| 在线天堂资源| 亚洲一区二区欧美激情| 亚洲人成影视在线观看| 青青草观看免费视频在线| 韩国av一区二区| 日本成熟性欧美| 国产91av视频| 欧美日韩午夜| 日韩中文字幕在线视频| 在线观看日本中文字幕| 加勒比久久高清| 欧美一区二区三级| 激情黄色小视频| 成人精品三级| 欧美性videos高清精品| 精品少妇人欧美激情在线观看| 在线国产91| 国产欧美日韩久久| 青青草国产精品| 天堂中文资源在线| 丰满少妇久久久久久久| 91综合免费在线| 国产精品国产三级国产普通话对白 | 国产精品免费av一区二区| 女人天堂亚洲aⅴ在线观看| 日韩中文字幕精品| 日本黄区免费视频观看| 国产探花一区在线观看| 国产亚洲福利一区| 国产熟妇久久777777| 性欧美lx╳lx╳| 日韩av在线播放资源| 人妻av一区二区| 激情视频极品美女日韩| 亚洲精品xxxx| 一区二区三区免费在线观看视频| 日本精品影院| 亚洲片国产一区一级在线观看| 亚洲第一成人网站| 精品99久久| 这里只有精品在线播放| 成人欧美一区二区三区黑人一 | 91麻豆文化传媒在线观看| 国产精品福利视频| 四虎影院在线播放| 久久综合九色欧美综合狠狠| 蜜桃视频在线观看91| 国产小视频在线| 中文字幕视频一区二区三区久| 99久久久无码国产精品性色戒| 伊人影院在线视频| 午夜亚洲福利老司机| jizzjizzxxxx| 欧美美女被草| 精品少妇一区二区三区| 国产精品无码网站| 日韩av有码| 九九热精品视频国产| 日韩欧美性视频| 老司机免费视频久久| 成人黄色网免费| 久久精品亚洲国产| 欧美亚洲综合另类| 日韩日韩日韩日韩日韩| 欧美一级鲁丝片| 欧美午夜片在线观看| 国内自拍第二页| 国产人妖ts一区二区| 亚洲免费伊人电影在线观看av| 美国黄色特级片| 黄色亚洲精品| 国产精品av在线播放| 国产人妖一区二区| 91亚洲精品一区二区乱码| 午夜精品一区二区在线观看的| fc2ppv国产精品久久| 一区二区三区精密机械公司| 不卡影院一区二区| 亚洲精品在线播放| 伊是香蕉大人久久| 久久免费精彩视频| 蜜桃视频一区二区| 精品视频在线观看| 黄色网址视频在线观看| 欧美日韩中文字幕综合视频| 久久久精品高清| 日韩伦理一区二区三区| 久久深夜福利免费观看| 亚洲影院在线播放| 高清shemale亚洲人妖| 色大师av一区二区三区| 538视频在线| 555www色欧美视频| 乐播av一区二区三区| 国产字幕视频一区二区| 国产精品一区二区3区| 男人天堂网在线视频| 国产精品成人一区二区三区夜夜夜| av免费观看大全| 激情五月综合婷婷| 最近2019中文字幕在线高清| 国产精品午夜影院| 国产99久久久久| 欧美日韩亚洲国产成人| 在线观看欧美日韩电影| 亚洲激情视频网站| 麻豆视频在线观看| 国产一区二区不卡| 亚洲制服中文| 国产一区二区三区影视| 亚洲男女性事视频| 日本少妇bbwbbw精品| 国产精品一级片在线观看| 亚洲乱码国产乱码精品天美传媒| 最近在线中文字幕| 日韩高清免费观看| 日韩成人免费在线视频| 国产成人精品网址| 黑人巨大国产9丨视频| 久久久加勒比| 日韩在线视频免费观看| 波多野结衣小视频| 国产日韩高清在线| 又色又爽又高潮免费视频国产| 欧美一区 二区| 91av中文字幕| 欧美精品少妇| 欧美在线观看一区| 成人精品一二三区| 精品一区二区久久久| 亚洲一区二区三区在线观看视频 | 一区二区三区 在线观看视频| 福利视频999| 伊人色**天天综合婷婷| 99在线视频首页| a级大胆欧美人体大胆666| 亚洲第一精品自拍| 91porny在线| 久久久99久久精品欧美| 99视频免费播放| 日韩欧美视频在线播放| 91精品久久久久久久久久另类 | 日批视频在线看| 欧美日韩国产色综合一二三四| av在线不卡观看| 九色porny视频在线观看| 日韩精品有码在线观看| 久久精品99北条麻妃| 国产精品国产三级国产aⅴ中文| 在线观看av网页| 欧美 日韩 国产 一区| 国产高清在线一区| 松下纱荣子在线观看| 亚洲欧美日韩另类| 91久久久久国产一区二区| 日韩美女视频19| 制服丝袜在线第一页| 老司机一区二区三区| 亚洲 国产 日韩 综合一区| 青青久久精品| 久久久最新网址| 国产天堂在线| 日韩欧美高清一区| 精品人妻无码一区二区性色| 国产精品美女久久久久久久网站| 亚洲综合123| 亚洲伊人观看| 在线看视频不卡| 日韩av影院| 国产区精品视频| 91超碰国产在线| 日韩中文字幕在线看| 天天操天天干天天爽| 欧美亚洲高清一区二区三区不卡| 欧美人妻精品一区二区三区| 久久久久国产精品麻豆| 中文字幕人妻无码系列第三区| 亚洲综合不卡| 樱空桃在线播放| 免费视频亚洲| 国产精品乱码视频| 日韩欧乱色一区二区三区在线| 久久久久中文字幕2018| 日本精品在线| 亚洲精品一区二区久| jlzzjlzzjlzz亚洲人| 在线一区二区视频| 日本三级视频在线| 亚洲品质自拍视频网站| 成人精品999| 成人av电影在线播放| 亚洲一区二区福利视频| 久久亚洲综合| 9久久9毛片又大又硬又粗| 亚洲精品国产偷自在线观看| 人禽交欧美网站免费| 久久悠悠精品综合网| 亚洲精品欧美极品| 久久久免费人体| 国产精品h在线观看| www在线观看黄色| 精品国产一区二区三区久久狼黑人 | 亚洲成人久久久| 精品二区在线观看| 欧美丰满美乳xxx高潮www| 这里只有精品国产| 色久优优欧美色久优优| 中国一级免费毛片| 亚洲国产成人高清精品| 欧美日韩在线观看成人| 中文字幕欧美一| 男人天堂资源网| 国产欧美日韩另类视频免费观看| 97人妻精品一区二区免费| 成人18视频在线播放| www.美色吧.com| 国产精品77777| 三级网站免费看| 国产一区二区精品久久| 巨乳女教师的诱惑| 国产福利91精品一区二区三区| 亚洲一区二区福利视频| 国产在线不卡一区| 亚洲在线观看网站| 国产福利不卡视频| 妖精视频一区二区| 99久久综合99久久综合网站| 国产a级黄色片| 99久久精品国产导航| 国产精品无码在线| 2020国产精品自拍| 国产综合精品在线| 中文字幕国产一区二区| 成人信息集中地| 亚洲美女视频在线观看| 国产成人av一区| 在线观看久久av| 三区视频在线观看| 精品影视av免费| av中文字幕网址| 国产一区91精品张津瑜| 国产黄色一区二区三区| 国产成人综合自拍| 国产女主播在线播放| 成a人片国产精品| 国产艳俗歌舞表演hd| 久久精品一区二区| 永久免费看片直接| 一个色妞综合视频在线观看| 国产性xxxx高清| 91福利国产精品| 国产乱码精品一区二区| 亚洲国产91精品在线观看| 免费黄色片在线观看| 精品国产一区二区三区久久| 丁香高清在线观看完整电影视频| 777精品视频| 欧美一级做a| 国产精品久久久久久久久久久久午夜片| 美女午夜精品| 亚洲mv在线看| 精品1区2区3区4区| 亚洲高清在线免费观看| 国产精品亚洲成人| 瑟瑟视频在线观看| 亚洲少妇30p| 亚洲 欧美 日韩 综合| 欧美日韩一二三| 四虎在线视频免费观看| 日韩中文字幕亚洲| 涩涩视频在线| 91网免费观看| 国产一区二区在线| 国产av熟女一区二区三区| 日本三级亚洲精品| 精品国产av色一区二区深夜久久| 欧美韩日一区二区三区| 日韩精品成人在线| 51精品视频一区二区三区| 午夜性色福利影院| 久久精品视频导航| 桃花岛tv亚洲品质| 国产成人亚洲欧美| 日韩国产一区二区| 黄色片视频在线免费观看| 国产做a爰片久久毛片| 国产人妻一区二区| 亚洲国产裸拍裸体视频在线观看乱了| 中文字幕av在线免费观看| 亚洲国产中文字幕在线观看| 九义人在线观看完整免费版电视剧| 97av在线视频| 一区二区三区在线免费看| 亚洲国产精品一区二区第四页av| 99国产精品久久久久久久成人热| 看看黄色一级片| 国产欧美1区2区3区| 91精品国产乱码久久久张津瑜| 欧美一级高清大全免费观看| 搞黄视频在线观看| 日韩美女中文字幕| 色愁久久久久久| 国产自产在线视频| 国产精品一品二品| 精品亚洲乱码一区二区| 在线观看亚洲精品| 精品视频一二区| 国产极品jizzhd欧美| 色橹橹欧美在线观看视频高清| 国产自产在线视频| 大胆亚洲人体视频| 久久这里只有精品国产| 日韩三级视频中文字幕| 成人影院在线观看| 亚洲xxxxx性| 影视亚洲一区二区三区| 日韩欧美色视频| 亚洲精品高清在线| 国产毛片毛片毛片毛片| 久久夜色精品国产欧美乱| 自拍偷拍欧美日韩| 激情五月五月婷婷| 国产99一区视频免费| 男人天堂中文字幕| 亚洲国产免费av| 性欧美18~19sex高清播放| 噜噜噜噜噜久久久久久91| 亚洲尤物影院| www.av欧美| 欧美日韩视频不卡| 成人毛片av在线| 国产精品久久久对白| 国产亚洲亚洲| 欧美 日韩 成人| 在线播放国产精品二区一二区四区| 午夜不卡视频| 97人人模人人爽视频一区二区| 国产精品啊啊啊| a天堂视频在线观看| 欧美日韩中文字幕综合视频| 国产小视频在线观看| 成人春色激情网| 亚洲视频免费| 波多野吉衣中文字幕| 欧美亚洲国产怡红院影院| 国产写真视频在线观看| 国产精品区一区二区三在线播放| 宅男噜噜噜66国产日韩在线观看| aaaaa级少妇高潮大片免费看| 欧美性猛片aaaaaaa做受| 黄a在线观看| 国产偷久久久精品专区| 久久夜色精品| 欧美黑吊大战白妞| 日韩精品极品毛片系列视频| 韩日一区二区| 国产精品久久久久久久乖乖| 久久久久一区二区三区四区| 国产精品国产三级国产普通话对白| 久久久久久久国产| 欧美日韩色图| 久久久久99人妻一区二区三区 | 国产suv精品一区二区68| 精品久久一区二区三区| 成人自拍av| 国产一线二线三线女| 国产欧美日韩另类视频免费观看| 国产成人三级一区二区在线观看一| 国产91成人video| 2023国产精品久久久精品双| 国产麻豆天美果冻无码视频 | 最好看的中文字幕| 色老汉av一区二区三区| 黄页网站大全在线免费观看| 日韩精品一区二区三区外面 | 在线视频第一页|