溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Oracle執(zhí)行計(jì)劃中常見index訪問方式有哪些

發(fā)布時(shí)間:2021-11-20 11:21:58 來源:億速云 閱讀:181 作者:小新 欄目:關(guān)系型數(shù)據(jù)庫

小編給大家分享一下Oracle執(zhí)行計(jì)劃中常見index訪問方式有哪些,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!

[SQL]
SELECT COUNT(*)
  FROM FDC_DATA
 WHERE EQPID = :B4
   AND UNIT = :B3
   AND PPID=:B2
   AND SENSOR=:B1
   AND EVENTTIME>SYSDATE-1/24

-----------------------------------------------------------------------------------
| Id  | Operation        | Name          | Starts | A-Rows |   A-Time   | Buffers |
-----------------------------------------------------------------------------------
|   0 | SELECT STATEMENT |               |      1 |      1 |00:00:00.25 |   18125 |
|   1 |  SORT AGGREGATE  |               |      1 |      1 |00:00:00.25 |   18125 |
|*  2 |   INDEX FULL SCAN| FDC_DATA_IDX1 |      1 |      1 |00:00:00.25 |   18124 |
-----------------------------------------------------------------------------------

 OLD INDEX:

   FDC_DATA_IDX1 : SYSID, EQPID, UNIT, PPID, SENSOR, PRODUCT, EVENTTIME, SPEC

   ---------------------------------------------------------------------------------------------

SELECT COUNT(*),COUNT(DISTINCT(SYSID) SYSID_NDV,.................... FROM TABLE;


    NDV(Number Of Distinct Value)

    COUNT(*)   SYSID_NDV  EQPID_NDV  UNIT_NDV   PPID_NDV   SENSOR_NDV  GLASSID_NDV
    ---------       ---------         ---------          ---------        ---------           ----------       -----------
       650430     100675           115               656              1515               2233        30139

NEW INDEX:
    FDC_DATA_IDX1 : SYSID
   FDC_DATA_IDX2 : EQPID, UNIT, PPID, EVENTTIME, SENSOR, GLASSID


------------------------------------------------------------------------------------
| Id  | Operation         | Name          | Starts | A-Rows |   A-Time    | Buffers |
------------------------------------------------------------------------------------
|   0 | SELECT STATEMENT  |               |      1 |      1 |00:00:00.001 |       3 |
|   1 |  SORT AGGREGATE   |               |      1 |      1 |00:00:00.001 |       3 |
|*  2 |   INDEX RANGE SCAN| FDC_DATA_IDX2 |      1 |      1 |00:00:00.001 |       3 |
------------------------------------------------------------------------------------

理解:創(chuàng)建index時(shí)

1. 分析應(yīng)用SQL條件中使用到的字段和后續(xù)各字段數(shù)據(jù)量的增長(zhǎng)情況;

2. 要檢查table各字段的distinct數(shù)量值;

3. 理論上建立復(fù)合索引時(shí),distinct數(shù)量值高的字段應(yīng)該放在復(fù)合索引首位,因?yàn)榉植级雀撸?/strong>

4. 如果某字段distinct數(shù)量值非常高,不建議使用太多字段的復(fù)合索引,建議單獨(dú)建立或者少字段的復(fù)合索引;

index 相關(guān)參考鏈接:http://www.xifenfei.com/2012/04/%e6%89%a7%e8%a1%8c%e8%ae%a1%e5%88%92%e4%b8%ad%e5%b8%b8%e8%a7%81index%e8%ae%bf%e9%97%ae%e6%96%b9%e5%bc%8f.html

http://www.xifenfei.com/2012/04/hint%e6%8c%87%e5%ae%9aindex%e7%9a%84%e6%b7%b1%e5%85%a5%e7%90%86%e8%a7%a3.html

index range scan(索引范圍掃描):

1.對(duì)于unique index來說,如果where 條件后面出現(xiàn)了<,> ,between ...and...的時(shí)候,那么就可能執(zhí)行index range scan,如果where條件后面是=,那么就會(huì)執(zhí)行index unique scan。

2.對(duì)于none unique index來說 如果where 條件后面出現(xiàn)了=,>,<,betweed...and...的時(shí)候,就有可能執(zhí)行index range scan。

3.對(duì)于組合索引來說,如果where條件后面出現(xiàn)了組合索引的引導(dǎo)列,那么可能執(zhí)行index range scan。

index fast full scan(索引快速全掃描):

如果select 語句后面中的列都被包含在組合索引中,而且where后面沒有出現(xiàn)組合索引的引導(dǎo)列,并且需要檢索出大部分?jǐn)?shù)據(jù),那么這個(gè)時(shí)候可能執(zhí)行index fast full scan。index fast full scan 發(fā)生的條件:

1.必須是組合索引。2.引導(dǎo)列不在where條件中

index skip scan(索引跳躍式掃描)

當(dāng)查詢可以通過組合索引得到結(jié)果,而且返回結(jié)果很少,并且where條件中沒有包含索引引導(dǎo)列的時(shí)候,可能執(zhí)行index skip scan

索引跳躍式掃描發(fā)生的條件:

1.必須是組合索引。

2.引導(dǎo)列沒有出現(xiàn)在where條件中

看完了這篇文章,相信你對(duì)“Oracle執(zhí)行計(jì)劃中常見index訪問方式有哪些”有了一定的了解,如果想了解更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI