綠(lǜ)色資(zī)源網:您身邊最放心的安全下載站! 最新(xīn)軟件|熱門排行|軟(ruǎn)件分類|軟件專題|廠(chǎng)商大全

綠(lǜ)色資源網

技術教程
您的位(wèi)置(zhì):首頁數據庫(kù)類(lèi)Oracle → oracle數據庫sql的優(yōu)化總結

oracle數據庫sql的優化總結

我要評論 2013/06/07 13:54:55 來源(yuán):綠色資(zī)源網 編(biān)輯:www.chithemodel.com [ ] 評論:0 點擊(jī):288次(cì)

自己對oracle sql的一些優化總(zǒng)結,自己也記錄下(xià)來,也希望對大(dà)家有幫助:

一:使用where少(shǎo)使用having;

二:查兩(liǎng)張以上(shàng)表(biǎo)時,把記錄少的放在右邊;

三:減少(shǎo)對表(biǎo)的(de)訪問次數;

四:有where子查詢時,子查詢放在最前;

五:select語(yǔ)句(jù)中盡量避免(miǎn)使用*(執行時會把*依次轉換為列名);

六:盡量多的使用commit;

七:Decode可以避免重(chóng)複掃描相同的記錄或重複連接(jiē)相同的表;

八:通過(guò)內部函數也可提高sql效率;

九:連接(jiē)多個表時,使用別名並(bìng)把別名前綴於每(měi)個字段(duàn)上;

十:用exists代替in

十一:not exists代替 not in(not in 字(zì)句(jù)將執行一個內部的排序和合並,任何(hé)情況下,not in是最(zuì)低(dī)效的,子查(chá)詢中全(quán)表掃描了。為了避免使用not in,可以改寫成outer joins或not exists);

十二:表連接(jiē)比exists更(gèng)高效;

十三:用exists替換distinct

       例: 

             低:                                                                    高:

             select distinct dept_no, dept_name                        select dept_no, dept_name

               from dept d, emp e                                               from dept d

            where d.dept_no = e.dept_no;                               where exists (select 1 from emp e where e.dept_no = d.dept_no);

十四:使用(yòng)TKPROF工具來查詢sql性能狀態;

十(shí)五(wǔ):用索引提高效(xiào)率(代價是:索(suǒ)引需要(yào)空間,而且(qiě)定(dìng)期重構索引(yǐn)很有必(bì)要:ALTER INDEX<INDEXNAME> REBUILD<TABLESPACENAME);

先介紹(shào)下索(suǒ)引的原理(lǐ),方便接下來對(duì)索引的優化的理解:

通過(guò)索(suǒ)引找到rowid,然後通過rowid訪問表。但(dàn)如(rú)果查(chá)詢(xún)的(de)列包括在index中,將不在執(zhí)行(háng)第二部操作,因為檢索數據保存(cún)在索引(yǐn)中,單單訪(fǎng)問索引就可以完全滿足(zú)查(chá)詢要求。

前提提(tí)要(yào):在十六例中,LODGING列有唯一索引;MANAGER列上(shàng)有非唯一性(xìng)索引。

十六:索引範圍查詢(INDEX RANGE SACEN):

        適用(yòng)於兩種(zhǒng)情(qíng)況:

        1)基於一個範圍的查詢:

              SELECT LODGING FROM LODGING WHERE LODGING LIKE 'M%'

        (where字句(jù)條件包括一係列的值,oracle將通過(guò)索(suǒ)引範圍查詢方式查詢LODGING_PK)

        2) 基於(yú)非唯一(yī)性(xìng)索引的檢索(suǒ):

              SELECT LODGING FROM LODGING WHERE MANAGER = 'LI';

         (此查詢分兩步:LODGING$MANAGER的索引範圍查詢得到所有符合條(tiáo)件記錄的rowid,然後(hòu)通過rowid訪問表(biǎo)得到LODGING列的值。該(gāi)索引為非唯一性索引,數(shù)據庫不(bú)能對(duì)它執(zhí)行索引唯一掃描)

where字句中,如果(guǒ)索引列所對應的值的第(dì)一個字符由通配符(fú)開始,索引將不被(bèi)采用(yòng),而會全表掃(sǎo)描,如 SELECT..... WHERE MANAGER LIKE '%LI'

十七:基礎(chǔ)表的選(xuǎn)擇:

        基礎表:最先訪問(wèn)的(de)表(通常以全表掃描的方式被訪問(wèn))。

        根據(jù)優化器(qì)的不同,SQL語句(jù)中基礎(chǔ)表的選擇(zé)是不一樣(yàng)的:

        如果使(shǐ)用CBO,優化器會檢查(chá)SQL語句中的每個表(biǎo)的(de)物理大小,索引的狀態,然後(hòu)選用(yòng)話(huà)費最低的路徑。

        如果使用RBO,並(bìng)且所(suǒ)有的連接條件都有索引對應(yīng),這種(zhǒng)情況下基礎表就是FROM字句中列在最後的(de)表

        例:

             SELECT A.NAME, B.MANAGER FROM WOKER A, LODGING B WHERE A.LODGING = B.LODGING;

             由於(yú)LODGING列上有一個索引,而且WORKER表中沒有相比較的索引,WORKER表將被作為查(chá)詢基礎表。

十八(bā):多個平等的索引:

        當SQL語句的執(zhí)行路徑可以使用分布在多個表(biǎo)上的多個索引時,oracle會同事使(shǐ)用多個索引(yǐn)並在運行(háng)時對它們的記錄合並,檢索(suǒ)僅對全部(bù)索引有效的記錄。

        oracle選擇執行(háng)路(lù)徑是,唯一索引等級高於(yú)非唯一索(suǒ)引(yǐn),隻有當where字句中索引列和常(cháng)量比較才有效。如(rú)果索引列和其它(tā)表的索引列相(xiàng)比較,這種字句在優化器中(zhōng)等級(jí)非常低;

        如果不同表中兩個(gè)相同等級的索引將被引用,根據FROM字句中(zhōng)表的順序決定哪個先被使(shǐ)用(yòng)。FROM字句中最後(hòu)的表索(suǒ)引優(yōu)先(xiān)級高。如果相同表中兩(liǎng)個相(xiàng)同(tóng)等級(jí)的索引將被引(yǐn)用,where字(zì)句中最先被引用的索引將有最高的(de)優(yōu)先級(jí)。

       例:DEPTNO上有(yǒu)非唯(wéi)一性索引,EMP_CAT也有(yǒu)非唯一性索引

            SELECT ENAME FROM EMP WHERE DEPT_NO = 20 AND EMP_CAT = 'A'; 

            DEPTNO索引將被先檢索,然後同EMP_CAT索引檢索出(chū)的結果合並,執行(háng)路徑如下(xià):

              TABLE ACCESS BY ROWID ON EMP

              AND _EQUAL

              INDEX RANGE SCAN ON  DEPT_IDX

              INDEX RANGE SCAN ON CAT_IDX

十九:等式比較與(yǔ)範圍比較:

       先上例子:

           SELECT ENAME FROM EMP WHERE DEPT_NO > 20 AND EMP_CAT = 'A';

         (在(zài)兩個非唯(wéi)一性索引前提下(xià))此時範圍索引不被(bèi)使用,通過EMP_CAT索(suǒ)引查詢出(chū)記錄再與DEPT_NO條件進行(háng)比(bǐ)較(jiào)

      注意(yì):唯(wéi)一性(xìng)所以做範圍比(bǐ)較(jiào)時,等級(jí)要比非唯一性索引的等式比(bǐ)較低(dī);

二十:強製索引失(shī)效:

        如果兩個或(huò)兩(liǎng)個以上索引具有相同的等級,可以強製命(mìng)令oracle優(yōu)化器使用其中的一個(gè)。 那何(hé)時使用(yòng)此(cǐ)種策(cè)略呢?如果一個索引已接近於唯一,而另一索引有很多重複的值,排序與(yǔ)合並反而會成為負擔,此時可以屏蔽(bì)後者使其索引失效。

       (失效方式:對索引列(liè)加入計算'+0'或'||""');

關鍵詞(cí):oracle,數據庫

閱讀本文後您有什麽(me)感想? 已有 人給出評價!

  • 0 歡迎(yíng)喜歡(huān)
  • 0 白癡
  • 0 拜托
  • 0 哇
  • 0 加油
  • 0 鄙視