Oracle認證:Oracle避免全表掃描方式
不知道各位同學提起Oracle認證考試來還頭疼嗎?還覺得沒有什麼複習頭緒嗎?下面小編就爲大家整理了一些Oracle認證複習備考資料。希望大家可以從中學習答題方法,讓自己的得到進步!
1.對返回的行無任何限定條件,即沒有where 子句
2.未對數據表與任何索引主列相對應的行限定條件
例如:在City-State-Zip列創建了三列複合索引,那麼僅對State列限定條件不能使用這個索引,因爲State不是索引的主列。
3.對索引的主列有限定條件,但是在條件表達式裏使用以下表達式則會使索引失效,造成全表掃描:
(1)where子句中對字段進行函數、表達式操作,這將導致引擎放棄使用索引而進行全表掃描,
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 時永遠不會使用索引。一般數據量大的表不要用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%' (使用索引)
解決辦法:首先儘量避免模糊查詢,如果因爲業務需要一定要使用模糊查詢,則至少保證不要使用全模糊查詢,對於右模糊查詢,即like '…%',是會使用索引的;左模糊like '%…'無法直接使用索引,但可以利用reverse + function index 的形式,變化成 like '…%';全模糊是無法優化的,一定要的話考慮用搜索引擎。出於降低數據庫服務器的負載考慮,儘可能地減少數據庫模糊查詢。
語句使用不當會引起全表掃描
原因:where子句中比較的兩個條件,一個有索引,一個沒索引,使用or則會引起全表掃描。例如:where A=:1 or B=:2,A上有索引,B上沒索引,則比較B=:2時會重新開始全表掃描
5.模糊查詢效率很低:
原因:like本身效率就比較低,應該儘量避免查詢條件使用like;對於like'%…%'(全模糊)這樣的條件,是無法使用索引的,全表掃描自然效率很低;另外,由於匹配算法的關係,模糊查詢的字段長度越大,模糊查詢效率越低。
解決辦法:首先儘量避免模糊查詢,如果因爲業務需要一定要使用模糊查詢,則至少保證不要使用全模糊查詢,對於右模糊查詢,即like'…%',是會使用索引的;左模糊like
'%…'無法直接使用索引,但可以利用reverse + function index的形式,變化成like'…%';全模糊是無法優化的,一定要的話考慮用搜索引擎。出於降低數據庫服務器的負載考慮,儘可能地減少數據庫模糊查詢。
6.查詢條件中含有is null的select語句執行慢
原因:Oracle 中,查詢字段is null時單索引失效,引起全表掃描。
解決方法:SQL語法中使用NULL會有很多麻煩,最好索引列都是NOT NULL的;對於is null,可以建立組合索引,nvl(字段,0),對錶和索引analyse後,is null查詢時可以重新啓用索引查找,但是效率還不是值得肯定;is not null時永遠不會使用索引。一般數據量大的表不要用is null查詢。
7.查詢條件中使用了不等於操作符(<>、!=)的select語句執行慢
原因:SQL中,不等於操作符會限制索引,引起全表掃描,即使比較的字段上有索引
解決方法:通過把不等於操作符改成or,可以使用索引,避免全表掃描。例如,把column<>'aaa',改成column<'aaa'or column>'aaa',就可以使用索引了。
8.使用組合索引,如果查詢條件中沒有前導列,那麼索引不起作用,會引起全表掃描;但是從Oracle9i開始,引入了索引跳躍式掃描的特性,可以允許優化器使用組合索引,即便索引的前導列沒有出現在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;前一種是全表掃描,後一種則會使用組合索引。
語句使用不當會引起全表掃描
原因:where子句中比較的.兩個條件,一個有索引,一個沒索引,使用or則會引起全表掃描。例如:where A=:1 or B=:2,A上有索引,B上沒索引,則比較B=:2時會重新開始全表掃描。
10.組合索引,排序時應按照組合索引中各列的順序進行排序,即使索引中只有一個列是要排序的,否則排序性能會比較差。例如:create index skip1 on emp5(job,empno,date); select job,empno from emp5 where job='manager'and empno='10'order by job,empno,date desc;實際上只是查詢出符合job='manager'and empno='10'條件的記錄並按date降序排列,但是寫成order by date desc性能較差。
相關文章
-
Oracle避免全表掃描方式
Oracle怎樣避免全表掃描呢,下面yjbys小編就爲大家整理了一些Oracle認證複習備考資料。希望大家可以從中學習答題方法,讓自己的得到進步!1.對返回的行無任何限定條件,即沒有where 子句2.未對數據表與任何索引主列相對應的 -
Oracle認證:OracleTRUNC函數詳解
C 函數Oracle TRUNC函數可以截取數字和日期類型: C截取數字TRUNC(number)函數返回n1截取到n2位小數。如果省略n2時,則n1截取到0位置(即截取所有小數位)。如果n2爲負數時,表示截取小數點左邊的n2位,被截取部分記爲0 -
Oracle認證:Oracle內存結構研究-PGA篇
一、概述SGA,PGA,UGA都是Oracle管理的內存區。SGA(System Global Area),即系統全局區,Oracle中最重要的內存區。PGA(Process Global Area),即程序全局區,一個進程的專用的內存區。UGA(User Global Area),即用戶全局區,與 -
Oracle認證:Win7下Oracle11g完全刪除
在不斷注重大學聯考能力提高的同時,尤其是Oracle認證備考的後階段,我們選擇的是求準求穩求規範。此複習輔導不等於題海戰術,而是要積累實戰經驗,解決掉一些考場失誤等問題。 1.關閉oracle所有的服務windows的.服務管理器(W -
Oracle認證:oracle中小寫轉換成大寫方法
一表堂堂【意思解釋】1.形容儀表堂皇。 -
Oracle認證:ORACLE綁定變量BINDPEEKING
ORACLE 在9i之後引入了bind peeking,通過bind peeking,oracle可以在硬解析的時候窺探綁定變量的值,並根據當前綁定變量的值生成執行計劃。在oracle 9i之前的版本中,oracle僅僅通過統計信息來生成執行計劃。下面看一下不 -
Oracle認證:Oracle控制件文件修復
查看文件頭SCN號:SQL> select file#, checkpoint_change# from v;FILE# CHECKPOINT_CHANGE#1 181200702 181200703 181200704 181200705 181200706 181200707 181200708 181200709 1812007010 1812007011 18121207FILE -
高中生優秀英語作文:Have a break away from electronics
It’s that time of the year again: school has started in full swing, homework is piling up and you realize that you can’t possibly wait for summer next year.I need a holiday, you may be thi -
英語作文:大學生村官 College Graduates Work as Village Offic
時間就如同白駒過隙般的流逝,前方等待着我們的是新的機遇和挑戰,是時候靜下心來好好寫寫計劃了。那麼你真正懂得怎麼制定計劃嗎?以下是小編整理的學校心理健康教育工作計劃,希望對大家有所幫助。學校心理健康教育工作計劃 -
Choice of large enterprises or small英語四級作文
無論在學習、工作或是生活中,大家都跟作文打過交道吧,作文是由文字組成,經過人的思想考慮,通過語言組織來表達一個主題意義的文體。怎麼寫作文才能避免踩雷呢?以下是小編精心整理的手拉手作文,歡迎大家分享。手拉手作文1“