小編給大家分享一下Oracle執(zhí)行計(jì)劃中常見index訪問方式有哪些,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!
10年的唐縣網(wǎng)站建設(shè)經(jīng)驗(yàn),針對(duì)設(shè)計(jì)、前端、開發(fā)、售后、文案、推廣等六對(duì)一服務(wù),響應(yīng)快,48小時(shí)及時(shí)工作處理。營(yíng)銷型網(wǎng)站的優(yōu)勢(shì)是能夠根據(jù)用戶設(shè)備顯示端的尺寸不同,自動(dòng)調(diào)整唐縣建站的顯示方式,使網(wǎng)站能夠適用不同顯示終端,在瀏覽器中調(diào)整網(wǎng)站的寬度,無論在任何一種瀏覽器上瀏覽網(wǎng)站,都能展現(xiàn)優(yōu)雅布局與設(shè)計(jì),從而大程度地提升瀏覽體驗(yàn)。成都創(chuàng)新互聯(lián)公司從事“唐縣網(wǎng)站設(shè)計(jì)”,“唐縣網(wǎng)站推廣”以來,每個(gè)客戶項(xiàng)目都認(rèn)真落實(shí)執(zhí)行。
[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)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!