溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

什么是函數(shù)索引

發(fā)布時間:2021-10-13 11:43:12 來源:億速云 閱讀:376 作者:iii 欄目:編程語言

本篇內(nèi)容主要講解“什么是函數(shù)索引”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“什么是函數(shù)索引”吧!

函數(shù)索引

在Oracle中,有一類特殊的索引,稱為函數(shù)索引(Function-Based Indexes,F(xiàn)BI),它基于對表中列進行計算后的結(jié)果創(chuàng)建索引。函數(shù)索引在不修改應用程序的邏輯基礎上提高了查詢性能。如果沒有函數(shù)索引,那么任何在列上執(zhí)行了函數(shù)的查詢都不能使用這個列的索引。當在查詢中包含該函數(shù)時,數(shù)據(jù)庫才會使用該函數(shù)索引。函數(shù)索引可以是一個B-Tree索引或位圖索引。

踩坑背景

1.生產(chǎn)環(huán)境某交易表數(shù)據(jù)量大約在20w左右,在根據(jù)具體條件查詢時,發(fā)現(xiàn)查詢特別慢。

什么是函數(shù)索引

(測試環(huán)境數(shù)據(jù))

2.查看表結(jié)構(gòu)發(fā)現(xiàn)日期字段沒有加索引

什么是函數(shù)索引

什么是函數(shù)索引

3.本想著直接對日期加上索引,應該就可以了。

create index IX_MESSAGE_MA_CREAT_TIME on MESSAGE (MA_CREAT_TIME)
  tablespace UTMSINDEX
  pctfree 10
  initrans 2
  maxtrans 255
  storage
  (
    initial 9M
    next 1M
    minextents 1
    maxextents unlimited
  );

4.但是再次查詢時發(fā)現(xiàn),查詢依舊很慢,通過查看Oracle解釋計劃,發(fā)現(xiàn)日期索引沒有使用。

什么是函數(shù)索引

5.創(chuàng)建函數(shù)索引

create index IX_MESSAGE_MA_CREAT_TIME on MESSAGE (to_char(MA_CREAT_TIME, 'yyyy-mm-dd'))
  tablespace UTMSINDEX
  pctfree 10
  initrans 2
  maxtrans 255
  storage
  (
    initial 9M
    next 1M
    minextents 1
    maxextents unlimited
  );

6.使用Oracle解釋計劃再次查詢,日期字段正常使用函數(shù)索引,查詢效率提高很多。

什么是函數(shù)索引

 

注意事項

1.函數(shù)索引創(chuàng)建時要和使用時保持一致

  • 創(chuàng)建時為:to_char(MA_CREAT_TIME, 'yyyy-mm-dd')

  • 查詢時也需使用:to_char(MA_CREAT_TIME, 'yyyy-mm-dd')

  • to_char(MA_CREAT_TIME, 'YYYY-MM-DD') 這樣就會失效

  • 任何不一致都會導致索引失效,其他函數(shù)同樣。


2.不建議使用自定義函數(shù)

  • 如果被函數(shù)索引所用的自定義函數(shù)失效或該函數(shù)索引的屬主沒有了在函數(shù)索引里面使用的函數(shù)的執(zhí)行權限,則會導致ORA-06575錯誤

  • 重新修改自定義函數(shù)并在編譯無報錯通過后,方可正常使用。


3.創(chuàng)建函數(shù)索引的函數(shù)必須是確定性的。即,對于指定的輸入,總是會有確定的結(jié)果。

4.創(chuàng)建索引的函數(shù)不能使用SUM、COUNT等聚合函數(shù)。

5.不能在LOB類型的列、NESTED TABLE列上創(chuàng)建函數(shù)索引。

6.不能使用SYSDATE、USER等非確定性函數(shù)。

7.對于任何用戶自定義函數(shù)必須顯式聲明DETERMINISTIC關鍵字,否則會導致ORA-30553:the funciton is not deterministic錯誤。

到此,相信大家對“什么是函數(shù)索引”有了更深的了解,不妨來實際操作一番吧!這里是億速云網(wǎng)站,更多相關內(nèi)容可以進入相關頻道進行查詢,關注我們,繼續(xù)學習!

向AI問一下細節(jié)

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

AI