SQL語句性能調整原則_第1頁
SQL語句性能調整原則_第2頁
SQL語句性能調整原則_第3頁
SQL語句性能調整原則_第4頁
SQL語句性能調整原則_第5頁
已閱讀5頁,還剩14頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

1、SQL語句性能調整原則語句性能調整原則SQL語句性能調整原則語句性能調整原則 一、問題的提出一、問題的提出在應用系統(tǒng)開發(fā)初期,由于開發(fā)數(shù)據(jù)庫數(shù)據(jù)在應用系統(tǒng)開發(fā)初期,由于開發(fā)數(shù)據(jù)庫數(shù)據(jù)比較少,對于查詢比較少,對于查詢SQL語句,復雜視圖的的語句,復雜視圖的的編寫等體會不出編寫等體會不出SQL語句各種寫法的性能優(yōu)語句各種寫法的性能優(yōu)劣,但是如果將應用系統(tǒng)提交實際應用后,劣,但是如果將應用系統(tǒng)提交實際應用后,隨著數(shù)據(jù)庫中數(shù)據(jù)的增加,系統(tǒng)的響應速度隨著數(shù)據(jù)庫中數(shù)據(jù)的增加,系統(tǒng)的響應速度就成為目前系統(tǒng)需要解決的最主要的問題之就成為目前系統(tǒng)需要解決的最主要的問題之一。一。 問題的提出問題的提出系統(tǒng)優(yōu)化中一

2、個很重要的方面就是系統(tǒng)優(yōu)化中一個很重要的方面就是SQL語句的優(yōu)化。對于海量數(shù)據(jù),劣語句的優(yōu)化。對于海量數(shù)據(jù),劣質質SQL語句和優(yōu)質語句和優(yōu)質SQL語句之間的速語句之間的速度差別可以達到上百倍,可見對于一度差別可以達到上百倍,可見對于一個系統(tǒng)不是簡單地能實現(xiàn)其功能就可,個系統(tǒng)不是簡單地能實現(xiàn)其功能就可,而是要寫出高質量的而是要寫出高質量的SQL語句,提高語句,提高系統(tǒng)的可用性。系統(tǒng)的可用性。 問題的提出問題的提出在多數(shù)情況下,在多數(shù)情況下,Oracle使用索引來更快地遍使用索引來更快地遍歷表,優(yōu)化器主要根據(jù)定義的索引來提高性歷表,優(yōu)化器主要根據(jù)定義的索引來提高性能。但是,如果在能。但是,如果在S

3、QL語句的語句的where子句中寫子句中寫的的SQL代碼不合理,就會造成優(yōu)化器刪去索代碼不合理,就會造成優(yōu)化器刪去索引而使用全表掃描,一般就這種引而使用全表掃描,一般就這種SQL語句就語句就是所謂的劣質是所謂的劣質SQL語句。在編寫語句。在編寫SQL語句時語句時我們應清楚優(yōu)化器根據(jù)何種原則來刪除索引,我們應清楚優(yōu)化器根據(jù)何種原則來刪除索引,這有助于寫出高性能的這有助于寫出高性能的SQL語句。語句。SQL語句編寫注意問題語句編寫注意問題 下面就某些下面就某些SQL語句的語句的where子句編寫中需要子句編寫中需要注意的問題作詳細介紹。在這些注意的問題作詳細介紹。在這些where子句中,子句中,即

4、使某些列存在索引,但是由于編寫了劣質即使某些列存在索引,但是由于編寫了劣質的的SQL,系統(tǒng)在運行該,系統(tǒng)在運行該SQL語句時也不能使語句時也不能使用該索引,而同樣使用全表掃描,這就造成用該索引,而同樣使用全表掃描,這就造成了響應速度的極大降低。了響應速度的極大降低。ISNULL與與ISNOTNULL不能用不能用null作索引,任何包含作索引,任何包含null值的列都值的列都將不會被包含在索引中。即使索引有多列這將不會被包含在索引中。即使索引有多列這樣的情況下,只要這些列中有一列含有樣的情況下,只要這些列中有一列含有null,該列就會從索引中排除。也就是說如果某列該列就會從索引中排除。也就是說如

5、果某列存在空值,即使對該列建索引也不會提高性存在空值,即使對該列建索引也不會提高性能。能。任何在任何在where子句中使用子句中使用isnull或或isnotnull的語句優(yōu)化器是不允許使用索引的。的語句優(yōu)化器是不允許使用索引的。SQL語句編寫注意問題語句編寫注意問題 SQL語句編寫注意問題語句編寫注意問題 下面是一個采用聯(lián)接查詢的下面是一個采用聯(lián)接查詢的SQL語句,語句,select*fromemployswherefirst_name|last_name=BeillCliton;上面這條語句完全可以查詢出是否有上面這條語句完全可以查詢出是否有BillCliton這個員工,這個員工,但是這里

6、需要注意,系統(tǒng)優(yōu)化器對基于但是這里需要注意,系統(tǒng)優(yōu)化器對基于last_name創(chuàng)建的創(chuàng)建的索引沒有使用。當采用下面這種索引沒有使用。當采用下面這種SQL語句的編寫,語句的編寫,Oracle系統(tǒng)就可以采用基于系統(tǒng)就可以采用基于last_name創(chuàng)建的索引。創(chuàng)建的索引。Select*fromemployeeWherefirst_name=Beillandlast_name=Cliton;SQL語句編寫注意問題語句編寫注意問題 SQL語句編寫注意問題語句編寫注意問題 SQL語句編寫注意問題語句編寫注意問題 Orderby語句語句ORDERBY語句決定了語句決定了Oracle如何將返回的查詢如何將返回

7、的查詢結果排序。結果排序。Orderby語句對要排序的列沒有什么語句對要排序的列沒有什么特別的限制,也可以將函數(shù)加入列中(象聯(lián)接或特別的限制,也可以將函數(shù)加入列中(象聯(lián)接或者附加等)。任何在者附加等)。任何在Orderby語句的非索引項或語句的非索引項或者有計算表達式都將降低查詢速度。者有計算表達式都將降低查詢速度。仔細檢查仔細檢查orderby語句以找出非索引項或者表達語句以找出非索引項或者表達式,它們會降低性能。解決這個問題的辦法就是式,它們會降低性能。解決這個問題的辦法就是重寫重寫orderby語句以使用索引,也可以為所使用語句以使用索引,也可以為所使用的列建立另外一個索引,同時應絕對避

8、免在的列建立另外一個索引,同時應絕對避免在orderby子句中使用表達式。子句中使用表達式。SQL語句編寫注意問題語句編寫注意問題 SQL語句編寫注意問題語句編寫注意問題 再看下面這個例子:再看下面這個例子:select*fromemployeewheresalary3000;對這個查詢,可以改寫為不使用對這個查詢,可以改寫為不使用NOT:select*fromemployeewheresalary3000;雖然這兩種查詢的結果一樣,但是第二種查雖然這兩種查詢的結果一樣,但是第二種查詢方案會比第一種查詢方案更快些。第二種詢方案會比第一種查詢方案更快些。第二種查詢允許查詢允許Oracle對對salary列使用索引,而第列使用索引,而第一種查詢則不能使用索引。一種查詢則不能使用索引。SQL語句編寫注意問題語句編寫注意問題 SQL語句編寫注意問題語句編寫注意問題 第二種格式中,子查詢以第二種格式中,子查詢以select*開始。運開始。運用用EXISTS子句不管子查詢從表中抽取什么數(shù)子句不管子查詢從表中抽取什么數(shù)據(jù)它只查看據(jù)它只查看where子句。這樣優(yōu)化器就不必遍子句。這樣優(yōu)化器就不必遍歷整個表而僅根據(jù)索引就可完成工作(這里假歷整個表而僅根據(jù)索引就可完成工作(這里假定在定在where語

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論