日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網為廣大站長提供免費收錄網站服務,提交前請做好本站友鏈:【 網站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(50元/站),

點擊這里在線咨詢客服
新站提交
  • 網站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747

概述

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

一文看懂Oracle數據庫的三大索引類型

 

一、B-Tree索引

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

1.1利用索引特性進行優化

外鍵上建立索引:不但可以提升查詢效率,而且可以有效避免鎖的競爭(外鍵所在表delete記錄未提交,主鍵所在表會被鎖住)。

  • 統計類查詢SQL:count(), avg(), sum(), max(), min()
  • 排序操作:order by字段建立索引
  • 去重操作:distinct
  • UNION/UNION ALL:union all不需要去重,不需要排序

1.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使用索引情況,因為索引過多會影響入庫性能。

1.3索引的危害

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

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

1.4索引的監控

 --監控
 alter index [index_name] monitoring usage;
 select * from v$object_usage;
 --取消監控: 
 alter index [index_name] nomonitoring usage;

根據對索引監控的結果,對長時間未使用的索引可以考慮將其刪除。
 

1.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 1=1 and substr(field,0,2) in ('01')

創建索引的語句就是

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

分享到:
標簽:Oracle
用戶無頭像

網友整理

注冊時間:

網站:5 個   小程序:0 個  文章:12 篇

  • 51998

    網站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

趕快注冊賬號,推廣您的網站吧!
最新入駐小程序

數獨大挑戰2018-06-03

數獨一種數學游戲,玩家需要根據9

答題星2018-06-03

您可以通過答題星輕松地創建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學四六

運動步數有氧達人2018-06-03

記錄運動步數,積累氧氣值。還可偷

每日養生app2018-06-03

每日養生,天天健康

體育訓練成績評定2018-06-03

通用課目體育訓練成績評定