日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

oracle三大索引类型

發布時間:2023/12/31 编程问答 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 oracle三大索引类型 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

詳解Oracle數據庫的三大索引類型

今天主要介紹Oracle數據庫的三大索引類型,僅供參考。下面,我們一起來看。

作者:波波說運維來源:今日頭條|2019-11-29 07:37

?收藏

??分享

今天主要介紹Oracle數據庫的三大索引類型,僅供參考。

一、B-Tree索引

三大特點:高度較低、存儲列值、結構有序

1. 利用索引特性進行優化

  • 外鍵上建立索引:不但可以提升查詢效率,而且可以有效避免鎖的競爭(外鍵所在表delete記錄未提交,主鍵所在表會被鎖住)。
  • 統計類查詢SQL:count(), avg(), sum(), max(), min()
  • 排序操作:order by字段建立索引
  • 去重操作:distinct
  • UNION/UNION ALL:union all不需要去重,不需要排序

2. 聯合索引

應用場景一:SQL查詢列很少,建立查詢列的聯合索引可以有效消除回表,但一般超過3個字段的聯合索引都是不合適的.

應用場景二:在字段A返回記錄多,在字段B返回記錄多,在字段A,B同時查詢返回記錄少,比如執行下面的查詢,結果c1,c2都很多,c3卻很少。

  • select?count(1)?c1?from?t?where?A?=?1;?
  • select?count(1)?c2?from?t?where?B?=?2;?
  • select?count(1)?c3?from?t?where?A?=?1?and?B?=?2;?
  • 聯合索引的列誰在前?

    普遍流行的觀點:重復記錄少的字段放在前面,重復記錄多的放在后面,其實這樣的結論并不準確。

  • drop?table?t?purge;?
  • create?table?t?as?select?*?from?dba_objects;?
  • create?index?idx1_object_id?on?t(object_id,object_type);?
  • create?index?idx2_object_id?on?t(object_type,object_id);?
  • 等值查詢:

  • select?*?from?t?where?object_id?=?20?and?object_type?=?'TABLE';?
  • select?/*+?index(t,idx1_object_id)?*/?*?from?t?where?object_id?=?20?and?object_type?=?'TABLE';?
  • select?/*+?index(t,idx2_object_id)?*/?*?from?t?where?object_id?=?20?and?object_type?=?'TABLE';?
  • 結論:等值查詢情況下,組合索引的列無論哪一列在前,性能都一樣。

    范圍查詢:

  • select?*?from?t?where?object_id?>=20?and?object_id?<?2000?and?object_type?=?'TABLE';?
  • select?/*+?index(t,idx1_object_id)?*/?*?from?t?where?object_id?>=20?and?object_id?<?2000?and?object_type?=?'TABLE';?
  • select?/*+?index(t,idx2_object_id)?*/?*?from?t?where?object_id?>=20?and?object_id?<?2000?and?object_type?=?'TABLE';?
  • 結論:組合索引的列,等值查詢列在前,范圍查詢列在后。 但如果在實際生產環境要確定組合索引列誰在前,要綜合考慮所有常用SQL使用索引情況,因為索引過多會影響入庫性能。

    3. 索引的危害

    表上有過多索引主要會嚴重影響插入性能;

    • 對delete操作,刪除少量數據索引可以有效快速定位,提升刪除效率,但是如果刪除大量數據就會有負面影響;
    • 對update操作類似delete,而且如果更新的是非索引列則無影響。

    4. 索引的監控

  • --監控?
  • alter?index?[index_name]?monitoring?usage;?
  • select?*?from?v$object_usage;?
  • --取消監控:??
  • alter?index?[index_name]?nomonitoring?usage;?
  • 根據對索引監控的結果,對長時間未使用的索引可以考慮將其刪除。

    5. 索引的常見執行計劃

    • INDEX FULL SCAN:索引的全掃描,單塊讀,有序
    • INDEX RANGE SCAN:索引的范圍掃描
    • INDEX FAST FULL SCAN:索引的快速全掃描,多塊讀,無序
    • INDEX FULL SCAN(MIN/MAX):針對MAX(),MIN()函數的查詢
    • INDEX SKIP SCAN:查詢條件沒有用到組合索引的第一列,而組合索引的第一列重復度較高時,可能用到

    二、位圖索引

    應用場景:表的更新操作極少,重復度很高的列。

    優勢:count(*) 效率高

  • create?table?t(?
  • name_id,?
  • gender?not?null,?
  • location?not?null,?
  • age_range?not?null,?
  • data?
  • )as?select??
  • rownum,?
  • decode(floor(dbms_random.value(0,2)),0,'M',1,'F')?gender,?
  • ceil(dbms_random.value(0,50))?location,?
  • decode(floor(dbms_random.value(0,4)),0,'child',1,'young',2,'middle',3,'old')?age_range,?
  • rpad('*',20,'*')?data?
  • from?dual?connect?by?rownum?<=?100000;??
  • create?index?idx_t?on?t(gender,location,age_range);?
  • create?bitmap?index?gender_idx?on?t(gender);?
  • create?bitmap?index?location_idx?on?t(location);?
  • create?bitmap?index?age_range_idx?on?t(age_range);?
  • select?*?from?t?where?gender?=?'M'?and?location?in?(1,10,30)?and?age_range?=?'child';?
  • select?/*+?index(t,idx_t)?*/*?from?t?where?gender?=?'M'?and?location?in?(1,10,30)?and?age_range?=?'child';?
  • 三、函數索引

    應用場景:不得不對某一列進行函數運算的場景。

    利用函數索引的效率要低于利用普通索引的。

    oracle中創建函數索引即是 你用到了什么函數就建什么函數索引,比如substr

  • select?*?from?table?where?11=1?and?substr(field,0,2)?in?('01')?
  • 創建索引的語句就是

  • create?index?indexname?on?table(substr(fileld,0,2))?online?nologging?;?
  • ?

    總結

    以上是生活随笔為你收集整理的oracle三大索引类型的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    主站蜘蛛池模板: 羞羞的视频网站 | 国产精品一线天 | 青青草原成人网 | 原神淫辱系列同人h | 97人妻一区二区精品免费视频 | 中文字幕一区二区三区人妻电影 | 欧美性在线观看 | 天堂一区在线观看 | 91国偷自产一区二区三区观看 | 欧美日韩在线免费观看视频 | youjizz日韩 | 丝袜av电影| 亚洲成人av免费观看 | 日本黄网站色大片免费观看 | 国产精品久久久久久网站 | 国产又粗又猛又爽又黄 | 泰剧19禁啪啪无遮挡 | 日韩色道 | 国产欧美一区二区精品久久久 | 亚洲精品二 | 亚洲一区a | wwwxxxx国产| 女生扒开尿口给男生捅 | av在线浏览 | 欧美在线91 | 日本护士体内she精2xxx | 特种兵之深入敌后高清全集免费观看 | 五月天激情小说 | 欧美不卡一区 | 亚洲欧美在线视频 | 欧美中文字幕在线 | 啪免费视频 | 中文在线视频观看 | 国产系列在线 | 久久精品美女 | 精品福利影院 | 天天人人精品 | 理论片高清免费理伦片 | 国内自拍视频网站 | 诱人的乳峰奶水hd | 国产chinesehd精品露脸 | 日韩美女视频网站 | 国产高潮白浆 | 日韩精品视频一区二区 | 日韩福利电影在线观看 | 中国毛片网站 | 欧美激情精品 | 天天插日日干 | 四虎影视www在线播放 | 草在线 | 少妇裸体挤奶汁奶水视频 | 欧美最猛黑人xxxx黑人猛交 | 欧美激情首页 | 熟妇人妻av无码一区二区三区 | 日韩一区二区三区视频在线 | 亚洲永久免费网站 | 极品人妻videosss人妻 | 欧美日韩亚洲激情 | 国产少妇一区二区 | 伊人久久av | av生活片| 欧美黄色一级片视频 | 精品人妻人伦一区二区有限公司 | 亚洲自拍偷拍色图 | 久草新免费 | 国产成人资源 | 久久91亚洲精品中文字幕奶水 | 欧美一级二级在线观看 | 粗大的内捧猛烈进出 | 亚洲免费视频网 | 五月网婷婷 | 亚洲欧美日韩久久精品 | 中文字幕精品国产 | 99热网址 | 欧美日韩在线免费视频 | 日本一区二区网站 | 日韩三级a | 国偷自拍 | 精品一区二区在线观看 | 青青草视频偷拍 | 一区二区三区在线播放 | 一级久久久久久久 | 中国一级片黄色一级片黄 | 男人视频网站 | 国v精品久久久网 | 美女又爽又黄视频毛茸茸 | 国产精品sm调教免费专区 | 制服丝袜一区二区三区 | 综合色婷婷一区二区亚洲欧美国产 | 人妻互换 综合 | 久久久久久久久国产精品一区 | 国产精品入口66mio | 亚洲视频在线免费看 | 好吊日精品视频 | 婷婷国产视频 | 天天色综合天天 | 人妻洗澡被强公日日澡电影 | 国产九九九 | 蜜臀av一区二区三区有限公司 |