偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

Oracle優(yōu)化SQL語(yǔ)句的好處

數(shù)據(jù)庫(kù) Oracle
以下的文章主要闡述的是在Oracle優(yōu)化SQL語(yǔ)句中,有很多的語(yǔ)句在優(yōu)化后,在實(shí)際的操作中更加的靈活,以下就是正文介紹。

如果你想更好的了解Oracle優(yōu)化SQL語(yǔ)句的話,你就必須的了解都有哪些SQL語(yǔ)句在Oracle中是經(jīng)常被使用到的,以下就是Oracle優(yōu)化SQL語(yǔ)句的相關(guān)內(nèi)容的具體介紹,希望你在瀏覽完此篇文章之后會(huì)有會(huì)所了解。

用WHERE替代ORDER BY:

ORDER BY 子句只在兩種嚴(yán)格的條件下使用索引。

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優(yōu)化SQL語(yǔ)句中應(yīng)避免改變索引列的類型:

當(dāng)比較不同數(shù)據(jù)類型的數(shù)據(jù)時(shí), Oracle自動(dòng)對(duì)列進(jìn)行簡(jiǎn)單的類型轉(zhuǎn)換。 假設(shè) EMPNO是個(gè)數(shù)值類型的索引列:SELECT … FROM EMP WHERE EMPNO = ‘123'。 實(shí)際上,經(jīng)過(guò)Oracle類型轉(zhuǎn)換, 語(yǔ)句轉(zhuǎn)化為: SELECT … FROM EMP WHERE EMPNO = TO_NUMBER(‘123') 。

幸運(yùn)的是,類型轉(zhuǎn)換沒(méi)有發(fā)生在索引列上,索引的用途沒(méi)有被改變。現(xiàn)在,假設(shè)EMP_TYPE是個(gè)字符類型的索引列:SELECT … FROM EMP WHERE EMP_TYPE = 123 。

這個(gè)語(yǔ)句被Oracle轉(zhuǎn)換為: SELECT … FROM EMP WHERETO_NUMBER(EMP_TYPE)=123。因?yàn)閮?nèi)部發(fā)生的類型轉(zhuǎn)換, 這個(gè)索引將不會(huì)被用到! 為了避免Oracle對(duì)您的SQL進(jìn)行隱式的類型轉(zhuǎn)換,最好把類型轉(zhuǎn)換用顯式表現(xiàn)出來(lái)。注意當(dāng)字符和數(shù)值比較時(shí),Oracle會(huì)優(yōu)先轉(zhuǎn)換數(shù)值類型到字符類型。

需要當(dāng)心的WHERE子句:

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

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

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

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

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

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

b. 在特定情況下,使用索引也許會(huì)比全表掃描慢,但這是同一個(gè)數(shù)量級(jí)上的區(qū)別。而通常情況下,使用索引比全表掃描要塊幾倍乃至幾千倍!

避免使用耗費(fèi)資源的操作:

帶有DISTINCT,UNION,MINUS,INTERSECT,ORDER BY的SQL語(yǔ)句會(huì)啟動(dòng)SQL引擎執(zhí)行耗費(fèi)資源的排序(SORT)功能。DISTINCT需要一次排序操作,而其他的至少需要執(zhí)行兩次排序。通常,帶有 UNION, MINUS , INTERSECT的SQL語(yǔ)句都能夠用其他方式重寫。假如您的數(shù)據(jù)庫(kù)的SORT_AREA_SIZE調(diào)配得好。

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

Oracle優(yōu)化GROUP BY:

提高GROUP BY 語(yǔ)句的效率,能夠通過(guò)將無(wú)需的記錄在GROUP BY 之前過(guò)濾掉。下面兩個(gè)查詢返回相同結(jié)果但第二個(gè)明顯就快了許多。

低效: 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數(shù)據(jù)庫(kù)緩沖區(qū)命中率的概述
  2. Oracle 10G for linux常用命令淺析
  3. Oracle 權(quán)限入門如何管理
  4. Oracle索引整理的詳細(xì)描述
  5. Oracle merge into的實(shí)操示例
責(zé)任編輯:佚名 來(lái)源: 互聯(lián)網(wǎng)
相關(guān)推薦

2009-03-04 09:06:56

優(yōu)化sqlOracle

2010-04-12 10:53:07

Oracle SQL

2010-04-26 14:32:21

Oracle SQL

2011-05-20 15:59:06

Oracle存儲(chǔ)Sql語(yǔ)句

2017-08-07 15:52:33

Oracleonnect by優(yōu)化

2010-04-13 15:14:31

Oracle優(yōu)化

2011-03-31 11:14:51

Sql語(yǔ)句優(yōu)化

2010-04-15 16:36:13

Oracle SQL

2009-11-16 17:55:58

Oracle SQL語(yǔ)

2010-04-06 14:26:41

Oracle復(fù)制表

2010-04-15 16:16:33

Oracle SQL

2009-11-16 13:47:35

Oracle SQL語(yǔ)

2018-01-09 16:56:32

數(shù)據(jù)庫(kù)OracleSQL優(yōu)化

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語(yǔ)句

2010-09-07 15:12:25

SQL語(yǔ)句優(yōu)化

2010-04-20 15:58:15

Oracle 語(yǔ)句

2010-11-04 15:39:40

DB2 SQL語(yǔ)句
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)