一区二区三区日韩精品-日韩经典一区二区三区-五月激情综合丁香婷婷-欧美精品中文字幕专区

分享

oracle優(yōu)化:避免全表掃描 .

 aaie_ 2013-04-02

1對返回的行無任何限定條件,即沒有where 子句

 

 

2未對數(shù)據(jù)表與任何索引主列相對應的行限定條件

例如:在City-State-Zip列創(chuàng)建了三列復合索引,那么僅對State列限定條件不能使用這個索引,因為State不是索引的主列。

 

3對索引的主列有限定條件,但是在條件表達式里使用以下表達式則會使索引失效,造成全表掃描:

1where子句中對字段進行函數(shù)、表達式操作,這將導致引擎放棄使用索引而進行全表掃描,

Demo:

where   upper(city)='TokYo' City || 'X' like 'TOKYO%',

select id from t where num/2=100   應改為:   select id from t where num=100*2

select * from emp where to_char(hire_date,'yyyymmdd')='20080411' (不使用)

select * from emp where hire_date = to_char('20080411','yyyymmdd') (使用)

 

2查詢字段is null時索引失效,引起全表掃描。

where City is null   ,where City is not null,

解決方法:SQL語法中使用NULL會有很多麻煩,最好索引列都是NOT NULL的;對于is null,可以建立組合索引,nvl(字段,0),對表和索引analyse后,is null查詢時可以重新啟用索引查找,但是效率還不是值得肯定;is not null 時永遠不會使用索引。一般數(shù)據(jù)量大的表不要用is null查詢。

select id from t where num is null

可以在num上設置默認值0,確保表中num列沒有null值,然后這樣查詢:

select id from t where num=0

 

(3)查詢條件中使用了不等于操作符(<>!=會限制索引、引起全表掃描

Where city!='TOKYO'.

解決方法:通過把不等于操作符改成or,可以使用索引,避免全表掃描。例如,把column<>’aaa’,改成column<’aaa’ or column>’aaa’,就可以使用索引了。

 

(4)對索引的主列有限定條件,但是條件使用like操作以及值%開始或者值是一個賦值變量。例如:

where City like '%YOK%'

where City like: City_bind_Variable xl_rao

select * from emp where name like '%A' (不使用索引)

select * from emp where name like 'A%' (使用索引)

解決辦法:首先盡量避免模糊查詢,如果因為業(yè)務需要一定要使用模糊查詢,則至少保證不要使用全模糊查詢,對于右模糊查詢,即like ‘…%’,是會使用索引的;左模糊like ‘%...’無法直接使用索引,但可以利用reverse + function index 的形式,變化成 like ‘…%’;全模糊是無法優(yōu)化的,一定要的話考慮用搜索引擎。出于降低數(shù)據(jù)庫服務器的負載考慮,盡可能地減少數(shù)據(jù)庫模糊查詢。

4 or語句使用不當會引起全表掃描

原因:where子句中比較的兩個條件,一個有索引,一個沒索引,使用or則會引起全表掃描。例如:where A=1 or B=2,A上有索引,B上沒索引,則比較B=2時會重新開始全表掃描

 

 

5模糊查詢效率很低:

  原因:like本身效率就比較低,應該盡量避免查詢條件使用like;對于like%...%’(全模糊)這樣的條件,是無法使用索引的,全表掃描自然效率很低;另外,由于匹配算法的關(guān)系,模糊查詢的字段長度越大,模糊查詢效率越低。

  解決辦法:首先盡量避免模糊查詢,如果因為業(yè)務需要一定要使用模糊查詢,則至少保證不要使用全模糊查詢,對于右模糊查詢,即like‘…%’,是會使用索引的;左模糊like

  ‘%...’無法直接使用索引,但可以利用reverse + function index的形式,變化成like‘…%’;全模糊是無法優(yōu)化的,一定要的話考慮用搜索引擎。出于降低數(shù)據(jù)庫服務器的負載考慮,盡可能地減少數(shù)據(jù)庫模糊查詢。

 

6查詢條件中含有is nullselect語句執(zhí)行慢

   原因:Oracle 中,查詢字段is null時單索引失效,引起全表掃描。

   解決方法:SQL語法中使用NULL會有很多麻煩,最好索引列都是NOT NULL的;對于is null,可以建立組合索引,nvl(字段,0),對表和索引analyse后,is null查詢時可以重新啟用索引查找,但是效率還不是值得肯定;is not null時永遠不會使用索引。一般數(shù)據(jù)量大的表不要用is null查詢。

 

7.查詢條件中使用了不等于操作符(<>、!=)的select語句執(zhí)行慢

  原因:SQL中,不等于操作符會限制索引,引起全表掃描,即使比較的字段上有索引

   解決方法:通過把不等于操作符改成or,可以使用索引,避免全表掃描。例如,把column<>aaa’,改成column<aaaor column>aaa’,就可以使用索引了。

 

8.使用組合索引,如果查詢條件中沒有前導列,那么索引不起作用,會引起全表掃描;但是從Oracle9i開始,引入了索引跳躍式掃描的特性,可以允許優(yōu)化器使用組合索引,即便索引的前導列沒有出現(xiàn)在WHERE子句中。例如:create index skip1 on emp5(job,empno);   全索引掃描select count(*) from emp5 where empno=7900;   索引跳躍式掃描select /*+ index(emp5 skip1)*/ count(*) from emp5 where empno=7900;前一種是全表掃描,后一種則會使用組合索引。

9. or語句使用不當會引起全表掃描

  原因:where子句中比較的兩個條件,一個有索引,一個沒索引,使用or則會引起全表掃描。例如:where A=1 or B=2,A上有索引,B上沒索引,則比較B=2時會重新開始全表掃描。

10.組合索引,排序時應按照組合索引中各列的順序進行排序,即使索引中只有一個列是要排序的,否則排序性能會比較差。例如:create index skip1 on emp5(job,empnodate);  select job,empno from emp5 where job=managerand empno=10order by job,empno,date desc;實際上只是查詢出符合job=managerand empno=10’條件的記錄并按date降序排列,但是寫成order by date desc性能較差。

 

11.Update語句,如果只更改1、2個字段,不要Update全部字段,否則頻繁調(diào)用會引起明顯的性能消耗,同時帶來大量日志。

  12.對于多張大數(shù)據(jù)量的表JOIN,要先分頁再JOIN,否則邏輯讀會很高,性能很差。

 

 13.select count(*) from table;這樣不帶任何條件的count會引起全表掃描,并且沒有任何業(yè)務意義,是一定要杜絕的。

  14.sqlwhere條件要綁定變量,比如where column=1,不要寫成where column=aaa’,這樣會導致每次執(zhí)行時都會重新分析,浪費CPU和內(nèi)存資源。

 

15.不要使用in操作符,這樣數(shù)據(jù)庫會進行全表掃描,

推薦方案:在業(yè)務密集的SQL當中盡量不采用IN操作符

 

16.not in 使用not in也不會走索引

推薦方案:用not exists或者(外聯(lián)結(jié)+判斷為空)來代替

 

 

17.> < 操作符(大于或小于操作符)

 

大于或小于操作符一般情況下是不用調(diào)整的,因為它有索引就會采用索引查找,但有的情況下可以對它進行優(yōu)化,如一個表有100萬記錄,一個數(shù)值型字段 A,30萬記錄的A=0,30萬記錄的A=1,39萬記錄的A=21萬記錄的A=3。那么執(zhí)行A>2A>=3的效果就有很大的區(qū)別了,因為A>2ORACLE會先找出為2的記錄索引再進行比較,而A>=3ORACLE則直接找到=3的記錄索引。

 

 

18.UNION操作符

 

UNION在進行表鏈接后會篩選掉重復的記錄,所以在表鏈接后會對所產(chǎn)生的結(jié)果集進行排序運算,刪除重復的記錄再返回結(jié)果。實際大部分應用中是不會產(chǎn)生重復的記錄,最常見的是過程表與歷史表UNION。如:

select * from gc_dfys

 

union

 

select * from ls_jg_dfys

 

這個SQL在運行時先取出兩個表的結(jié)果,再用排序空間進行排序刪除重復的記錄,最后返回結(jié)果集,如果表數(shù)據(jù)量大的話可能會導致用磁盤進行排序。

 

推薦方案:采用UNION ALL操作符替代UNION,因為UNION ALL操作只是簡單的將兩個結(jié)果合并后就返回。

 

19.WHERE后面的條件順序影響

 

WHERE子句后面的條件順序?qū)Υ髷?shù)據(jù)量表的查詢會產(chǎn)生直接的影響,如

 

Select * from zl_yhjbqk where dy_dj = '1K以下' and xh_bz=1

 

Select * from zl_yhjbqk where xh_bz=1 and dy_dj = '1K以下'

 

以上兩個SQLdy_djxh_bz兩個字段都沒進行索引,所以執(zhí)行的時候都是全表掃描,第一條SQLdy_dj = '1KV以下'條件在記錄集內(nèi)比率為99%,而xh_bz=1的比率只為0.5%,在進行第一條SQL的時候99%條記錄都進行dy_djxh_bz的比較,而在進行第二條SQL的時候0.5%條記錄都進行dy_djxh_bz的比較,以此可以得出第二條SQLCPU占用率明顯比第一條低。

 

20.查詢表順序的影響

 

FROM后面的表中的列表順序會對SQL執(zhí)行性能影響,在沒有索引及ORACLE沒有對表進行統(tǒng)計分析的情況下ORACLE會按表出現(xiàn)的順序進行鏈接,由此因為表的順序不對會產(chǎn)生十分耗服務器資源的數(shù)據(jù)交叉。(注:如果對表進行了統(tǒng)計分析,ORACLE會自動先進小表的鏈接,再進行大表的鏈接)

    本站是提供個人知識管理的網(wǎng)絡存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點。請注意甄別內(nèi)容中的聯(lián)系方式、誘導購買等信息,謹防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊一鍵舉報。
    轉(zhuǎn)藏 分享 獻花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多

    国产精品一区二区成人在线| 东京热男人的天堂久久综合| 一本色道久久综合狠狠躁| 日韩精品毛片视频免费看| 免费黄片视频美女一区| 在线观看欧美视频一区| 久久精品国产99精品亚洲| 国产精品日韩欧美一区二区| 丝袜人妻夜夜爽一区二区三区| 亚洲精品一区二区三区免 | 黄片三级免费在线观看| 大香蕉伊人精品在线观看| 不卡视频免费一区二区三区| 国产一区二区三中文字幕| 色偷偷偷拍视频在线观看| 亚洲第一区欧美日韩在线| 日韩精品毛片视频免费看| 日本深夜福利在线播放| 精品日韩中文字幕视频在线| 亚洲超碰成人天堂涩涩| 午夜精品福利视频观看| 日本高清中文精品在线不卡| 精品人妻一区二区三区四区久久| 精品少妇人妻av免费看| 免费大片黄在线观看日本| 欧美精品久久男人的天堂| 婷婷伊人综合中文字幕| 日韩性生活片免费观看| 国产原创中文av在线播放| 国产亚洲欧美日韩精品一区| 日本成人三级在线播放| 亚洲二区欧美一区二区| 国产午夜福利一区二区| 日韩一区二区三区在线日| 欧美日韩亚洲精品在线观看| 免费特黄一级一区二区三区| 女人精品内射国产99| 欧美精品一区久久精品| 日本精品视频一二三区| 蜜桃传媒在线正在播放| 午夜激情视频一区二区|