Oracle 對(duì)某列的部分?jǐn)?shù)據(jù)創(chuàng)建索引
成都創(chuàng)新互聯(lián)公司主營(yíng)進(jìn)賢網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營(yíng)網(wǎng)站建設(shè)方案,成都App制作,進(jìn)賢h5成都小程序開發(fā)搭建,進(jìn)賢網(wǎng)站營(yíng)銷推廣歡迎進(jìn)賢等地區(qū)企業(yè)咨詢
--- 說(shuō)明:案例來(lái)自《 收獲,不止SQL 優(yōu)化 》
請(qǐng)問(wèn):Oracle 可以針對(duì)某列的部分?jǐn)?shù)據(jù)創(chuàng)建索引嗎?比如 t1 表 id 列的數(shù)據(jù)有 1,2,3,4,5 。可以只針對(duì) id=3 的數(shù)據(jù)創(chuàng)建索引嗎?
可以通過(guò)函數(shù)索引實(shí)現(xiàn)只針對(duì)id=3 的數(shù)據(jù)創(chuàng)建索引,例如 :
Create index i_t1_id on t(case when id=3 then 3 end);
請(qǐng)問(wèn):請(qǐng)舉一個(gè)具體案例,并說(shuō)明在該場(chǎng)景下使用部分索引性能更好?
案例如下:
---創(chuàng)建測(cè)試表t
SQL > create table t ( id int , status varchar2 ( 2 ));
--建立普通索引
SQL > create index id_normal on t ( status );
-- 插入數(shù)據(jù)
SQL > insert into t select rownum , 'Y' from dual connect by rownum <= 100000 ;
SQL > insert into t select 1 , 'N' from dual ;
SQL > commit ;
---數(shù)據(jù)分布
SQL > select count (*), status from t group by status ;
--- 收集統(tǒng)計(jì)信息
SQL > analyze table t compute statistics for table for all indexes for all indexed columns ;
--- 查詢表 t ,查看執(zhí)行計(jì)劃
SQL > set linesize 1000
SQL > set autotrace traceonly
SQL > select * from t where status = 'N' ;
-- 查 看索引 信息
SQL > set autotrace off
SQL > analyze index id_normal validate structure ;
SQL > select name , btree_space , lf_rows , height from index_stats ;
備注 : INDEX_STATS 存儲(chǔ)的是最近一次 ANALYZE INDEX ... VALIDATE STRUCTURE 語(yǔ)句的結(jié)果,最多只有 當(dāng)前會(huì)話的 一條數(shù)據(jù) 。
--- 創(chuàng)建函數(shù)索引的情況
SQL > drop index id_normal ;
SQL > create index id_status on t ( Case when status = 'N' then 'N' end );
SQL > analyze table t compute statistics for table for all indexes for all indexed columns ;
--- 再次查看執(zhí)行計(jì)劃
SQL > set autotrace traceonly
SQL > select * from t where ( case when status = 'N' then 'N' end )= 'N' ;
--觀察id_status索引的情況
SQL > set autotrace off
SQL > analyze index id_status validate structure ;
SQL > select name , btree_space , lf_rows , height from index_stats ;
--- 在對(duì)比下之前普通索引的值
結(jié)論: 普通索引改成函數(shù)索引后,索引當(dāng)前分配的空間 (BTREE_SPACE) 由 20230168 降到 7996 , , 邏輯讀consistent gets 由 5 降到 2 ,索引葉子數(shù) (LF_ROWS) 由 100001 降到 1 ,索引高度 (HEIGHT) 由 3 降到 1 ,性能有所提升。
歡迎關(guān)注我的微信公眾號(hào)"IT小Chen",共同學(xué)習(xí),共同成長(zhǎng)?。?!