亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > Oracle > 正文

oracle數據庫sql的優化總結

2024-08-29 13:56:58
字體:
來源:轉載
供稿:網友

一:使用where少使用having;

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

三:減少對表的訪問次數;

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

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

六:盡量多的使用commit;

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

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

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

十:用exists代替in

十一:not exists代替 not in(not in 字句將執行一個內部的排序和合并,任何情況下,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性能狀態;

十五:用索引提高效率(代價是:索引需要空間,而且定期重構索引很有必要:ALTER INDEX<INDEXNAME> REBUILD<TABLESPACENAME);

先介紹下索引的原理,方便接下來對索引的優化的理解:

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

前提提要:在十六例中,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列的值。該索引為非唯一性索            引,數據庫不能對它執行索引唯一掃描)

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

十七:基礎表的選擇:

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

        根據優化器的不同,SQL語句中基礎表的選擇是不一樣的:

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

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

        例:

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

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

十八:多個平等的索引:

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

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

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

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

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

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

              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優化器使用其中的一個。 那何時使用此種策略呢?如果一個索引已接近于唯一,而另一索引有很多重復的值,排序與合并反而會成為負擔,此時可以屏蔽后者使其索引失效。

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
夜夜嗨av一区二区三区免费区| 97av在线视频免费播放| 欧美精品久久久久久久久| 国产欧美一区二区三区在线| 日韩国产中文字幕| 97久久精品人搡人人玩| 日韩视频在线观看免费| 国产精品久久久久77777| 午夜精品一区二区三区在线视频| 日韩在线资源网| 国产精品久久久久久亚洲调教| 欧美亚洲另类在线| 国产精品高潮呻吟久久av黑人| 国产精品扒开腿爽爽爽视频| 久久精品福利视频| 精品国产欧美成人夜夜嗨| 精品五月天久久| 69av在线播放| 午夜精品久久久久久99热软件| 欧美性猛交xxxx偷拍洗澡| 91精品国产高清久久久久久| 97在线视频免费看| 亚洲a一级视频| 国产视频久久久久久久| 国内精品久久久久影院优| 在线播放日韩专区| 欧美裸体xxxx极品少妇软件| 国产亚洲日本欧美韩国| 国产精品成人观看视频国产奇米| 精品久久久久久中文字幕大豆网| 色中色综合影院手机版在线观看| 久久国产精品免费视频| 国产情人节一区| 在线观看国产成人av片| 日韩欧中文字幕| 精品亚洲一区二区三区在线播放| 97色在线播放视频| 国产精品观看在线亚洲人成网| 国产一区二区三区毛片| 国产欧美最新羞羞视频在线观看| 在线播放日韩欧美| 亚洲欧美激情四射在线日| 欧美噜噜久久久xxx| 亚洲人在线观看| 午夜精品一区二区三区视频免费看| 色哟哟亚洲精品一区二区| 日韩在线中文字幕| 欧美性xxxx在线播放| 色综合91久久精品中文字幕| 日本午夜精品理论片a级appf发布| 欧美精品一区三区| 97在线看免费观看视频在线观看| 精品中文字幕在线观看| 欧美成人自拍视频| 久久精品国产一区| 国产激情综合五月久久| 国产精品一久久香蕉国产线看观看| 欧美激情视频免费观看| 亚洲一区二区三区在线免费观看| 亚洲片在线观看| 日韩中文在线视频| 亚洲免费人成在线视频观看| 国产69精品久久久久9999| 亚洲精品在线看| 亚洲免费人成在线视频观看| 日韩电影中文字幕在线| 2019最新中文字幕| 久久久久久久久久久久久久久久久久av| 久久99久久99精品中文字幕| 精品视频久久久久久久| 精品久久久香蕉免费精品视频| 精品亚洲一区二区三区在线播放| 51午夜精品视频| 日产日韩在线亚洲欧美| 精品国内亚洲在观看18黄| 亚洲精品国产suv| 91国自产精品中文字幕亚洲| 欧美网站在线观看| 久久国产精品久久国产精品| 亚洲少妇激情视频| 久久在线精品视频| 欧美另类精品xxxx孕妇| 91高清视频免费观看| 国产精品国产自产拍高清av水多| 九九热最新视频//这里只有精品| 5566成人精品视频免费| 欧美日韩成人在线播放| 亚洲视频欧美视频| 精品久久久免费| 亚洲精品久久视频| 欧洲成人性视频| 欧美成人国产va精品日本一级| 久久久久久久999精品视频| 欧美激情视频在线免费观看 欧美视频免费一| 亚洲美女福利视频网站| 国产视频精品一区二区三区| 中文字幕亚洲一区在线观看| 日韩视频一区在线| 中文字幕视频在线免费欧美日韩综合在线看| 国产精品人成电影在线观看| 日韩av网站在线| 国产婷婷色综合av蜜臀av| 国产日韩在线免费| 亚洲午夜精品久久久久久久久久久久| 91精品久久久久久久久久| 亚洲视频国产视频| 亚洲欧美国产精品久久久久久久| 国产精品偷伦免费视频观看的| 中文字幕在线看视频国产欧美在线看完整| 久久久久久综合网天天| 国产自摸综合网| 欧美一级在线亚洲天堂| 粉嫩老牛aⅴ一区二区三区| 日本国产精品视频| 国产成人精品日本亚洲| 狠狠久久亚洲欧美专区| 69影院欧美专区视频| 久久精品99久久久久久久久| 国产精品美女在线观看| 亚洲xxx视频| 欧美日韩成人黄色| 亚洲第一网中文字幕| 午夜精品一区二区三区视频免费看| 亚洲黄色在线看| 自拍偷拍亚洲精品| 久久噜噜噜精品国产亚洲综合| 日韩av在线免费| 亚洲欧美另类自拍| 日韩专区在线播放| 日韩精品在线视频| 中文字幕av一区二区三区谷原希美| 久久精品视频播放| 亚洲国产精品成人精品| 97精品视频在线观看| 7m第一福利500精品视频| 欧美肥婆姓交大片| 国产精品扒开腿做爽爽爽的视频| 成人综合网网址| 国产精品大陆在线观看| 97视频在线观看免费高清完整版在线观看| 亚洲欧洲自拍偷拍| 国产精品久久国产精品99gif| 欧美人与物videos| 78m国产成人精品视频| 一区二区三区视频观看| 久久视频免费在线播放| 欧美野外猛男的大粗鳮| 国产69精品久久久久99| 亚洲一区中文字幕在线观看| 久久久久免费精品国产| 中文字幕在线观看亚洲| 亚洲精品资源在线| 亚洲一区二区福利| 国产精品日日做人人爱| 亚洲欧美日韩综合| 国产精品一区二区三区毛片淫片| 久久久久久久久久久国产| 国产欧美日韩免费| 中文字幕在线看视频国产欧美| 中文字幕亚洲二区| 九九热最新视频//这里只有精品| 久久91亚洲人成电影网站| 中文字幕久久亚洲| 欧美怡春院一区二区三区|