成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Oracle優化SQL語句的好處

數據庫 Oracle
以下的文章主要闡述的是在Oracle優化SQL語句中,有很多的語句在優化后,在實際的操作中更加的靈活,以下就是正文介紹。

如果你想更好的了解Oracle優化SQL語句的話,你就必須的了解都有哪些SQL語句在Oracle中是經常被使用到的,以下就是Oracle優化SQL語句的相關內容的具體介紹,希望你在瀏覽完此篇文章之后會有會所了解。

用WHERE替代ORDER BY:

ORDER BY 子句只在兩種嚴格的條件下使用索引。

ORDER BY中任何的列必須包含在相同的索引中并保持在索引中的排列順序。

ORDER BY中任何的列必須定義為非空。

WHERE子句使用的索引和ORDER BY子句中所使用的索引不能并列。

例如: 表DEPT包含以下列:

 

  1. DEPT_CODE PK NOT NULL  
  2. DEPT_DESC NOT NULL  
  3. DEPT_TYPE NULL  

 

低效: (索引不被使用)

 

  1. SELECT DEPT_CODE FROM DEPT ORDER BY DEPT_TYPE 

高效: (使用索引)

 

  1. SELECT DEPT_CODE FROM DEPT WHERE DEPT_TYPE > 0 

在Oracle優化SQL語句中應避免改變索引列的類型:

當比較不同數據類型的數據時, 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會優先轉換數值類型到字符類型。

需要當心的WHERE子句:

某些SELECT 語句中的WHERE子句不使用索引。這里有一些例子:

(1)‘!=' 將不使用索引。記住, 索引只能告訴您什么存在于表中, 而不能告訴您什么不存在于表中。

(2)‘||'是字符連接函數。就象其他函數那樣, 停用了索引。

(3)‘ '是數學函數。就象其他數學函數那樣, 停用了索引。

(4)相同的索引列不能互相比較,這將會啟用全表掃描。

(32)a. 假如檢索數據量超過30%的表中記錄數,使用索引將沒有顯著的效率提高。

b. 在特定情況下,使用索引也許會比全表掃描慢,但這是同一個數量級上的區別。而通常情況下,使用索引比全表掃描要塊幾倍乃至幾千倍!

避免使用耗費資源的操作:

帶有DISTINCT,UNION,MINUS,INTERSECT,ORDER BY的SQL語句會啟動SQL引擎執行耗費資源的排序(SORT)功能。DISTINCT需要一次排序操作,而其他的至少需要執行兩次排序。通常,帶有 UNION, MINUS , INTERSECT的SQL語句都能夠用其他方式重寫。假如您的數據庫的SORT_AREA_SIZE調配得好。

使用UNION , MINUS, INTERSECT也是能夠考慮的, 畢竟他們的可讀性很強。

Oracle優化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

【編輯推薦】

  1. Oracle數據庫緩沖區命中率的概述
  2. Oracle 10G for linux常用命令淺析
  3. Oracle 權限入門如何管理
  4. Oracle索引整理的詳細描述
  5. Oracle merge into的實操示例
責任編輯:佚名 來源: 互聯網
相關推薦

2009-03-04 09:06:56

優化sqlOracle

2010-04-12 10:53:07

Oracle SQL

2010-04-26 14:32:21

Oracle SQL

2011-05-20 15:59:06

Oracle存儲Sql語句

2010-04-13 15:14:31

Oracle優化

2017-08-07 15:52:33

Oracleonnect by優化

2011-03-31 11:14:51

Sql語句優化

2010-04-15 16:36:13

Oracle SQL

2009-11-16 13:47:35

Oracle SQL語

2010-04-15 16:16:33

Oracle SQL

2009-01-14 09:28:12

OracleSQL10g

2010-04-20 15:22:34

Oracle SQL

2010-04-29 14:06:40

Oracle SQL

2010-04-12 14:22:13

Oracle性能sql語句

2009-11-16 17:55:58

Oracle SQL語

2010-04-06 14:26:41

Oracle復制表

2010-04-20 15:58:15

Oracle 語句

2010-11-04 15:39:40

DB2 SQL語句

2018-01-09 16:56:32

數據庫OracleSQL優化

2010-09-07 15:12:25

SQL語句優化
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 免费看黄色片 | 亚洲小视频在线观看 | 亚洲欧洲成人av每日更新 | 日韩在线一区二区 | 日韩无| 久久国产区 | 久久久国产精品一区 | 亚洲欧美在线观看视频 | 欧洲精品久久久久毛片完整版 | 91视频精选 | 欧美精品成人一区二区三区四区 | 久久99精品久久久久久 | 亚洲精品区 | 国产欧美日韩一区二区三区在线观看 | 国产精品一区二区不卡 | 女人一区| 中文字幕av一区二区三区 | 亚洲精品一区二区三区中文字幕 | 国产欧美在线 | 韩国主播午夜大尺度福利 | 精品国产乱码久久久久久果冻传媒 | 久久精品a| 欧美一区二区三区在线观看视频 | 成人在线视频免费播放 | 91夜色在线观看 | www.97zyz.com| 国产精品日韩欧美一区二区 | 中文字幕免费在线观看 | 毛片免费在线观看 | 大陆一级毛片免费视频观看 | av在线电影网 | 91精品国产日韩91久久久久久 | 精品一区av | 亚洲一av| 一区亚洲 | 中文字幕日本一区二区 | 午夜一区 | 日韩视频免费 | 亚洲二区在线 | 51ⅴ精品国产91久久久久久 | 欧美中文字幕一区二区三区亚洲 |