主頁 > 知識庫 > oracle數(shù)據(jù)庫sql的優(yōu)化總結(jié)

oracle數(shù)據(jù)庫sql的優(yōu)化總結(jié)

熱門標(biāo)簽:征服眼公司地圖標(biāo)注 美圖秀秀地圖標(biāo)注 征服者火車站地圖標(biāo)注 百度地圖標(biāo)注素材 外呼線路外顯本地號碼 阿爾巴尼亞地圖標(biāo)注app 人工智能地圖標(biāo)注自己能做嗎 word地圖標(biāo)注方向 開封智能外呼系統(tǒng)廠家

一:使用where少使用having;

二:查兩張以上表時,把記錄少的放在右邊;

三:減少對表的訪問次數(shù);

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

五:select語句中盡量避免使用*(執(zhí)行時會把*依次轉(zhuǎn)換為列名);

六:盡量多的使用commit;

七:Decode可以避免重復(fù)掃描相同的記錄或重復(fù)連接相同的表;

八:通過內(nèi)部函數(shù)也可提高sql效率;

九:連接多個表時,使用別名并把別名前綴于每個字段上;

十:用exists代替in

十一:not exists代替 not in(not in 字句將執(zhí)行一個內(nèi)部的排序和合并,任何情況下,not in是最低效的,子查詢中全表掃描了。為了避免使用not in,可以改寫成outer joins或not exists);

十二:表連接比exists更高效;

十三:用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);

十四:使用TKPROF工具來查詢sql性能狀態(tài);

十五:用索引提高效率(代價是:索引需要空間,而且定期重構(gòu)索引很有必要:ALTER INDEXINDEXNAME> REBUILDTABLESPACENAME);

先介紹下索引的原理,方便接下來對索引的優(yōu)化的理解:

     通過索引找到rowid,然后通過rowid訪問表。但如果查詢的列包括在index中,將不在執(zhí)行第二部操作,因為檢索數(shù)據(jù)保存在索引中,單單訪問索引就可以完全滿足查詢要求。

前提提要:在十六例中,LODGING列有唯一索引;MANAGER列上有非唯一性索引。

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

        適用于兩種情況:

        1)基于一個范圍的查詢:

              SELECT LODGING FROM LODGING WHERE LODGING LIKE 'M%'

        (where字句條件包括一系列的值,oracle將通過索引范圍查詢方式查詢LODGING_PK)

        2) 基于非唯一性索引的檢索:

              SELECT LODGING FROM LODGING WHERE MANAGER = 'LI';

         (此查詢分兩步:LODGING$MANAGER的索引范圍查詢得到所有符合條件記錄的rowid,然后通過rowid訪問表得到LODGING列的值。該索引為非唯一性索            引,數(shù)據(jù)庫不能對它執(zhí)行索引唯一掃描)

where字句中,如果索引列所對應(yīng)的值的第一個字符由通配符開始,索引將不被采用,而會全表掃描,如 SELECT..... WHERE MANAGER LIKE '%LI'

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

        基礎(chǔ)表:最先訪問的表(通常以全表掃描的方式被訪問)。

        根據(jù)優(yōu)化器的不同,SQL語句中基礎(chǔ)表的選擇是不一樣的:

            如果使用CBO,優(yōu)化器會檢查SQL語句中的每個表的物理大小,索引的狀態(tài),然后選用話費最低的路徑。

            如果使用RBO,并且所有的連接條件都有索引對應(yīng),這種情況下基礎(chǔ)表就是FROM字句中列在最后的表

        例:

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

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

十八:多個平等的索引:

        當(dāng)SQL語句的執(zhí)行路徑可以使用分布在多個表上的多個索引時,oracle會同事使用多個索引并在運行時對它們的記錄合并,檢索僅對全部索引有效的記錄。

        oracle選擇執(zhí)行路徑是,唯一索引等級高于非唯一索引,只有當(dāng)where字句中索引列和常量比較才有效。如果索引列和其它表的索引列相比較,這種字句在優(yōu)化器中等級非常低;

        如果不同表中兩個相同等級的索引將被引用,根據(jù)FROM字句中表的順序決定哪個先被使用。FROM字句中最后的表索引優(yōu)先級高。如果相同表中兩個相同等級的索引將被引用,where字句中最先被引用的索引將有最高的優(yōu)先級。

       例:DEPTNO上有非唯一性索引,EMP_CAT也有非唯一性索引

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

            DEPTNO索引將被先檢索,然后同EMP_CAT索引檢索出的結(jié)果合并,執(zhí)行路徑如下:

              TABLE ACCESS BY ROWID ON EMP

              AND _EQUAL

              INDEX RANGE SCAN ON  DEPT_IDX

              INDEX RANGE SCAN ON CAT_IDX

十九:等式比較與范圍比較:

       先上例子:

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

         (在兩個非唯一性索引前提下)此時范圍索引不被使用,通過EMP_CAT索引查詢出記錄再與DEPT_NO條件進行比較

      注意:唯一性所以做范圍比較時,等級要比非唯一性索引的等式比較低;

二十:強制索引失效:

        如果兩個或兩個以上索引具有相同的等級,可以強制命令oracle優(yōu)化器使用其中的一個。 那何時使用此種策略呢?如果一個索引已接近于唯一,而另一索引有很多重復(fù)的值,排序與合并反而會成為負擔(dān),此時可以屏蔽后者使其索引失效。

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

您可能感興趣的文章:
  • oracle 性能優(yōu)化建議小結(jié)
  • Oracle性能究極優(yōu)化
  • Oracle性能究極優(yōu)化 下
  • Oracle之SQL語句性能優(yōu)化(34條優(yōu)化方法)
  • Oracle 查詢優(yōu)化的基本準(zhǔn)則詳解
  • Oracle 數(shù)據(jù)庫優(yōu)化實戰(zhàn)心得總結(jié)
  • oracle下一條SQL語句的優(yōu)化過程(比較詳細)
  • Oracle性能究極優(yōu)化(Oracle 性能優(yōu)化)
  • Oracle SQL性能優(yōu)化系列學(xué)習(xí)一
  • Linux中大內(nèi)存頁Oracle數(shù)據(jù)庫優(yōu)化的方法

標(biāo)簽:泰安 葫蘆島 酒泉 孝感 淮南 海北 六安 宜春

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《oracle數(shù)據(jù)庫sql的優(yōu)化總結(jié)》,本文關(guān)鍵詞  oracle,數(shù)據(jù)庫,sql,的,優(yōu)化,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《oracle數(shù)據(jù)庫sql的優(yōu)化總結(jié)》相關(guān)的同類信息!
  • 本頁收集關(guān)于oracle數(shù)據(jù)庫sql的優(yōu)化總結(jié)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章