亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Oracle 語句優(yōu)化分析說明

 更新時間:2009年09月17日 21:52:20   作者:  
Oracle 語句優(yōu)化技巧,大家可以參考使用,使你的oracle運行效率更高更好。

15. 避免在索引列上使用NOT
通常,我們要避免在索引列上使用 NOT,NOT 會產(chǎn)生在和在索引列上使用函數(shù)相同
的影響。當ORACLE“遇到”NOT,他就會停止使用索引轉(zhuǎn)而執(zhí)行全表掃描。
舉例:
低效: (這里,不使用索引)
SELECT …
FROM DEPT
WHERE DEPT_CODE NOT = 0;
高效: (這里,使用了索引)
SELECT …
FROM DEPT
WHERE DEPT_CODE > 0;
16. 用>=替代>
如果 DEPTNO 上有一個索引,
高效:
SELECT *
FROM EMP
WHERE DEPTNO >=4
低效:
SELECT *
FROM EMP
WHERE DEPTNO >3
兩者的區(qū)別在于, 前者 DBMS將直接跳到第一個 DEPT 等于 4的記錄而后者將首先
定位到 DEPTNO=3的記錄并且向前掃描到第一個 DEPT 大于 3的記錄。
17. 用UNION替換OR (適用于索引列)
通常情況下, 用 UNION替換 WHERE 子句中的 OR將會起到較好的效果。 對索引列使用 OR將造成全表掃描。注意, 以上規(guī)則只針對多個索引列有效。 如果有 column沒有被索引, 查詢效率可能會因為你沒有選擇 OR而降低。 在下面的例子中, LOC_ID 和 REGION上都建有索引。
高效:
SELECT LOC_ID , LOC_DESC , REGION
FROM LOCATION
WHERE LOC_ID = 10
UNION
SELECT LOC_ID , LOC_DESC , REGION
FROM LOCATION
WHERE REGION = “MELBOURNE”
低效:
SELECT LOC_ID , LOC_DESC , REGION FROM LOCATION
WHERE LOC_ID = 10 OR REGION = “MELBOURNE”
如果你堅持要用 OR, 那就需要返回記錄最少的索引列寫在最前面。
18. 用IN來替換OR
下面的查詢可以被更有效率的語句替換:
低效:
SELECT…
FROM LOCATION
WHERE LOC_ID = 10
OR LOC_ID = 20
OR LOC_ID = 30
高效:
SELECT…
FROM LOCATION
WHERE LOC_IN IN (10,20,30);
:這是一條簡單易記的規(guī)則,但是實際的執(zhí)行效果還須檢驗,在 ORACLE8i 下,兩者
的執(zhí)行路徑似乎是相同的。
19. 避免在索引列上使用IS NULL和IS NOT NULL
避免在索引中使用任何可以為空的列,ORACLE 將無法使用該索引。對于單列索引,
如果列包含空值,索引中將不存在此記錄。 對于復合索引,如果每個列都為空,索引中同樣不存在此記錄。 如果至少有一個列不為空,則記錄存在于索引中。
舉例:
如果唯一性索引建立在表的 A列和 B 列上, 并且表中存在一條記錄的 A, B 值為(123,null) , ORACLE 將不接受下一條具有相同 A,B 值(123,null)的記錄(插入)。 然而如果所有的索引列都為空, ORACLE 將認為整個鍵值為空而空不等于空。 因此你可以插入 1000條具有相同鍵值的記錄,當然它們都是空! 因為空值不存在于索引列中,所以 WHERE 子句中對索引列進行空值比較將使ORACLE 停用該索引。
舉例:
低效:(索引失效)
SELECT …
FROM DEPARTMENT WHERE DEPT_CODE IS NOT NULL;
高效:(索引有效)
SELECT …
FROM DEPARTMENT
WHERE DEPT_CODE >=0;
20. 用UNION ALL替換 UNION( 如果有可能的話)
當 SQL語句需要 UNION兩個查詢結果集合時,這兩個結果集合會以 UNION-ALL的方式被合并, 然后在輸出最終結果前進行排序。 如果用 UNION ALL替代 UNION, 這樣排序就不是必要了。 效率就會因此得到提高。
舉例:
低效:
SELECT ACCT_NUM, BALANCE_AMT
FROM DEBIT_TRANSACTIONS
WHERE TRAN_DATE = ‘31-DEC-95'
UNION
SELECT ACCT_NUM, BALANCE_AMT
FROM DEBIT_TRANSACTIONS
WHERE TRAN_DATE = ‘31-DEC-95'
高效:
SELECT ACCT_NUM, BALANCE_AMT
FROM DEBIT_TRANSACTIONS
WHERE TRAN_DATE = ‘31-DEC-95'
UNION ALL
SELECT ACCT_NUM, BALANCE_AMT
FROM DEBIT_TRANSACTIONS
WHERE TRAN_DATE = ‘31-DEC-95'
:需要注意的是,UNION ALL 將重復輸出兩個結果集合中相同記錄。 因此各位還是
要從業(yè)務需求分析使用 UNION ALL 的可行性。UNION 將對結果集合排序,這個操作會使用到 SORT_AREA_SIZE這塊內(nèi)存。 對于這塊內(nèi)存的優(yōu)化也是相當重要的。 下面的 SQL可以用來查詢排序的消耗量
Select substr(name,1,25) "Sort Area Name",
substr(value,1,15) "Value"
from v$sysstat
where name like 'sort%'
21. 優(yōu)化GROUP BY
提高 GROUP BY 語句的效率, 可以通過將不需要的記錄在 GROUP BY 之前過濾掉。下面兩個查詢返回相同結果但第二個明顯就快了許多。
低效:
SELECT JOB , AVG(SAL)
FROM EMP
GROUP by JOB
HAVING JOB = ‘PRESIDENT'
OR JOB = ‘MANAGER'
高效:
SELECT JOB , AVG(SAL)
FROM EMP
WHERE JOB = ‘PRESIDENT'
OR JOB = ‘MANAGER'GROUP by JOB

相關文章

  • oracle設置mybatis自動生成id插入方式

    oracle設置mybatis自動生成id插入方式

    這篇文章主要介紹了oracle設置mybatis自動生成id插入方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • Oracle數(shù)據(jù)庫升級或數(shù)據(jù)遷移方法研究

    Oracle數(shù)據(jù)庫升級或數(shù)據(jù)遷移方法研究

    本文詳細論述了oracle數(shù)據(jù)庫升級的升級前的準備、升級過程和升級后的測試與調(diào)整工作,并對各種升級方法在多種操作系統(tǒng)平臺上作了測試。
    2016-07-07
  • oracle插入字符串數(shù)據(jù)時字符串中有''單引號問題

    oracle插入字符串數(shù)據(jù)時字符串中有''單引號問題

    這篇文章主要介紹了oracle插入字符串數(shù)據(jù)時字符串中有'單引號問題的相關資料,需要的朋友可以參考下
    2017-04-04
  • Oracle查看邏輯讀、物理讀資源占用排行的SQL語句

    Oracle查看邏輯讀、物理讀資源占用排行的SQL語句

    這篇文章主要介紹了Oracle查看邏輯讀、物理讀資源占用排行的SQL語句,需要的朋友可以參考下
    2014-10-10
  • Oracle的CLOB大數(shù)據(jù)字段類型操作方法

    Oracle的CLOB大數(shù)據(jù)字段類型操作方法

    VARCHAR2既分PL/SQL Data Types中的變量類型,也分Oracle Database中的字段類型,不同場景的最大長度不同。接下來通過本文給大家分享Oracle的CLOB大數(shù)據(jù)字段類型操作方法,感興趣的朋友一起看看吧
    2017-08-08
  • Oracle表碎片整理操作步驟詳解

    Oracle表碎片整理操作步驟詳解

    數(shù)據(jù)庫在日常使用過程中,不斷的insert,delete,update操作,導致表和索引出現(xiàn)碎片是在所難免的事情,碎片多了,sql的執(zhí)行效率自然就差了,下面看看如何表碎片整理,提高執(zhí)行效率
    2013-11-11
  • Oracle終極徹底卸載的完整步驟

    Oracle終極徹底卸載的完整步驟

    這篇文章主要給大家介紹了關于Oracle終極徹底卸載的完整步驟,文中通過圖文介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-11-11
  • Oracle例外用法實例詳解

    Oracle例外用法實例詳解

    這篇文章主要介紹了Oracle例外用法,結合實例形式較為詳細的分析了Oracle例外的概念,功能及相關使用技巧,需要的朋友可以參考下
    2016-03-03
  • Oracle中ROW_NUMBER()OVER()函數(shù)用法實例講解

    Oracle中ROW_NUMBER()OVER()函數(shù)用法實例講解

    Oracle中的row_number()函數(shù)用于在查詢結果中為每一行生成一個唯一的行號,下面這篇文章主要給大家介紹了關于Oracle中ROW_NUMBER()OVER()函數(shù)用法的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-04-04
  • And,Where使用提示以及用+進行左關聯(lián)的提示及注意事項

    And,Where使用提示以及用+進行左關聯(lián)的提示及注意事項

    先左關聯(lián)后在過濾假如關聯(lián)的結果里面B.b3=null那么你在where后面在加B.b3=2那么結果中B.b3肯定是沒有null的情況的,也就是說用+進行左關聯(lián)沒有用leftjoin靈活待后續(xù)看是否有什么好的解決方案
    2013-02-02

最新評論