ORACLE優化SQL語句,提高效率(3)
ORDER BY 子句只在兩種嚴格的條件下使用索引。
ORDER BY中任何的列必須包含在相同的索引中並保持在索引中的排列順序。
ORDER BY中任何的列必須定義為非空。
WHERE子句使用的索引和ORDER BY子句中所使用的索引不能並列。
例如: 表DEPT包含以下列:
DEPT_CODE PK NOT NULL
DEPT_DESC NOT NULL
DEPT_TYPE NULL
低效: (索引不被使用)
SELECT DEPT_CODE FROM DEPT ORDER BY DEPT_TYPE
高效: (使用索引)
SELECT DEPT_CODE FROM DEPT WHERE DEPT_TYPE > 0
(30)避免改變索引列的型別:
當比較不同資料型別的資料時, ORACLE自動對列進行簡單的型別轉換。 假設 EMPNO是個數值型別的索引列:SELECT … FROM EMP WHERE EMPNO = ‘123'。 實際上,經過Oracle型別轉換, 語句轉化為: SELECT … FROM EMP WHERE EMPNO = TO_NUMBER(‘123') 。
幸運的是,型別轉換沒有發生在索引列上,索引的用途沒有被改變。現在,假設EMP_TYPE是個字元型別的索引列:SELECT … FROM EMP WHERE EMP_TYPE = 123 。
這個語句被Oracle轉換為: SELECT … FROM EMP WHERETO_NUMBER(EMP_TYPE)=123。因為內部發生的型別轉換, 這個索引將不會被用到! 為了避免Oracle對您的SQL進行隱式的型別轉換,最好把型別轉換用顯式表現出來。注意當字元和數值比較時,Oracle會優先轉換數值型別到字元型別。
(31)需要當心的WHERE子句:
某些SELECT 語句中的WHERE子句不使用索引。這裡有一些例子:
(1)‘!=' 將不使用索引。記住, 索引只能告訴您什麼存在於表中, 而不能告訴您什麼不存在於表中。
(2)‘||'是字元連線函式。就象其他函式那樣, 停用了索引。
(3)‘ '是數學函式。就象其他數學函式那樣, 停用了索引。
(4)相同的索引列不能互相比較,這將會啟用全表掃描。
(32)a. 假如檢索資料量超過30%的表中記錄數,使用索引將沒有顯著的效率提高。
b. 在特定情況下,使用索引也許會比全表掃描慢,但這是同一個數量級上的區別。而通常情況下,使用索引比全表掃描要塊幾倍乃至幾千倍!
(33)避免使用耗費資源的操作:
帶有DISTINCT,UNION,MINUS,INTERSECT,ORDER BY的SQL語句會啟動SQL引擎執行耗費資源的排序(SORT)功能。DISTINCT需要一次排序操作,而其他的至少需要執行兩次排序。通常,帶有 UNION, MINUS , INTERSECT的SQL語句都能夠用其他方式重寫。假如您的資料庫的SORT_AREA_SIZE調配得好。使用UNION , MINUS, INTERSECT也是能夠考慮的, 畢竟他們的可讀性很強。
(34)優化GROUP BY:
提高GROUP BY 語句的效率,能夠通過將無需的記錄在GROUP BY 之前過濾掉。下面兩個查詢返回相同結果但第二個明顯就快了許多。
低效: SELECT JOB , AVG(SAL) FROM EMP GROUP JOB HAVING JOB = ‘PRESIDENT' OR JOB = ‘MANAGER' 高效: SELECT JOB , AVG(SAL) FROM EMP WHERE JOB = ‘PRESIDENT' OR JOB = ‘MANAGER' GROUP JOB
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/219982/viewspace-620028/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- SQL語句優化SQL優化
- sql語句效能優化SQL優化
- MYSQL SQL語句優化MySql優化
- 【SQL】Oracle 表新增列提高效率語句參考SQLOracle
- MySQL之SQL語句優化MySql優化
- [20201210]sql語句優化.txtSQL優化
- 優化 SQL 語句的步驟優化SQL
- Oracle基本SQL語句OracleSQL
- [20200320]SQL語句優化的困惑.txtSQL優化
- SQL查詢語句 (Oracle)SQLOracle
- Oracle SQL精妙SQL語句講解OracleSQL
- ORACLE中sql語句----運算子的優先順序OracleSQL
- [20181114]一條sql語句的優化.txtSQL優化
- 《MySQL慢查詢優化》之SQL語句及索引優化MySql優化索引
- SQL優化案例-單表分頁語句的優化(八)SQL優化
- Java中如何解析SQL語句、格式化SQL語句、生成SQL語句?JavaSQL
- Oracle優化案例-單表分頁語句的優化(八)Oracle優化
- 列出oracle dbtime得sql語句OracleSQL
- MySQL 52個SQL效能優化策略SQL語句彙總MySql優化
- SQL語句優化的原則與方法QOSQL優化
- [20200324]SQL語句優化的困惑2.txtSQL優化
- Sql語句本身的優化-定位慢查詢SQL優化
- 後臺執行SQL語句(oracle)SQLOracle
- SQL語句最佳化SQL
- [20210205]警惕toad下優化直方圖相關sql語句3.txt優化直方圖SQL
- Mysql 52條SQL語句效能優化策略彙總MySql優化
- sql語句執行順序與效能優化(1)SQL優化
- MySql常用30種SQL查詢語句優化方法MySql優化
- 【SQL】Oracle SQL join on語句and和where使用區別SQLOracle
- java連線oracle執行sql語句JavaOracleSQL
- soar-PHP - SQL 語句優化器和重寫器的 PHP 擴充套件包、 方便框架中 SQL 語句調優PHPSQL優化套件框架
- [20211229]toad下優化sql語句注意的問題.txt優化SQL
- Oracle效能優化-SQL優化(案例一)Oracle優化SQL
- Oracle效能優化-SQL優化(案例二)Oracle優化SQL
- Oracle效能優化-SQL優化(案例三)Oracle優化SQL
- Oracle效能優化-SQL優化(案例四)Oracle優化SQL
- MySQL——優化ORDER BY語句MySql優化
- Oracle SQL優化之sql tuning advisorOracleSQL優化
- Oracle執行語句跟蹤 使用sql trace實現語句追蹤OracleSQL