




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、SQL語句性能調(diào)整原則語句性能調(diào)整原則SQL語句性能調(diào)整原則語句性能調(diào)整原則 一、問題的提出一、問題的提出在應(yīng)用系統(tǒng)開發(fā)初期,由于開發(fā)數(shù)據(jù)庫數(shù)據(jù)在應(yīng)用系統(tǒng)開發(fā)初期,由于開發(fā)數(shù)據(jù)庫數(shù)據(jù)比較少,對于查詢比較少,對于查詢SQL語句,復(fù)雜視圖的的語句,復(fù)雜視圖的的編寫等體會不出編寫等體會不出SQL語句各種寫法的性能優(yōu)語句各種寫法的性能優(yōu)劣,但是如果將應(yīng)用系統(tǒng)提交實(shí)際應(yīng)用后,劣,但是如果將應(yīng)用系統(tǒng)提交實(shí)際應(yīng)用后,隨著數(shù)據(jù)庫中數(shù)據(jù)的增加,系統(tǒng)的響應(yīng)速度隨著數(shù)據(jù)庫中數(shù)據(jù)的增加,系統(tǒng)的響應(yīng)速度就成為目前系統(tǒng)需要解決的最主要的問題之就成為目前系統(tǒng)需要解決的最主要的問題之一。一。 問題的提出問題的提出系統(tǒng)優(yōu)化中一
2、個(gè)很重要的方面就是系統(tǒng)優(yōu)化中一個(gè)很重要的方面就是SQL語句的優(yōu)化。對于海量數(shù)據(jù),劣語句的優(yōu)化。對于海量數(shù)據(jù),劣質(zhì)質(zhì)SQL語句和優(yōu)質(zhì)語句和優(yōu)質(zhì)SQL語句之間的速語句之間的速度差別可以達(dá)到上百倍,可見對于一度差別可以達(dá)到上百倍,可見對于一個(gè)系統(tǒng)不是簡單地能實(shí)現(xiàn)其功能就可,個(gè)系統(tǒng)不是簡單地能實(shí)現(xiàn)其功能就可,而是要寫出高質(zhì)量的而是要寫出高質(zhì)量的SQL語句,提高語句,提高系統(tǒng)的可用性。系統(tǒng)的可用性。 問題的提出問題的提出在多數(shù)情況下,在多數(shù)情況下,Oracle使用索引來更快地遍使用索引來更快地遍歷表,優(yōu)化器主要根據(jù)定義的索引來提高性歷表,優(yōu)化器主要根據(jù)定義的索引來提高性能。但是,如果在能。但是,如果在S
3、QL語句的語句的where子句中寫子句中寫的的SQL代碼不合理,就會造成優(yōu)化器刪去索代碼不合理,就會造成優(yōu)化器刪去索引而使用全表掃描,一般就這種引而使用全表掃描,一般就這種SQL語句就語句就是所謂的劣質(zhì)是所謂的劣質(zhì)SQL語句。在編寫語句。在編寫SQL語句時(shí)語句時(shí)我們應(yīng)清楚優(yōu)化器根據(jù)何種原則來刪除索引,我們應(yīng)清楚優(yōu)化器根據(jù)何種原則來刪除索引,這有助于寫出高性能的這有助于寫出高性能的SQL語句。語句。SQL語句編寫注意問題語句編寫注意問題 下面就某些下面就某些SQL語句的語句的where子句編寫中需要子句編寫中需要注意的問題作詳細(xì)介紹。在這些注意的問題作詳細(xì)介紹。在這些where子句中,子句中,即
4、使某些列存在索引,但是由于編寫了劣質(zhì)即使某些列存在索引,但是由于編寫了劣質(zhì)的的SQL,系統(tǒng)在運(yùn)行該,系統(tǒng)在運(yùn)行該SQL語句時(shí)也不能使語句時(shí)也不能使用該索引,而同樣使用全表掃描,這就造成用該索引,而同樣使用全表掃描,這就造成了響應(yīng)速度的極大降低。了響應(yīng)速度的極大降低。ISNULL與與ISNOTNULL不能用不能用null作索引,任何包含作索引,任何包含null值的列都值的列都將不會被包含在索引中。即使索引有多列這將不會被包含在索引中。即使索引有多列這樣的情況下,只要這些列中有一列含有樣的情況下,只要這些列中有一列含有null,該列就會從索引中排除。也就是說如果某列該列就會從索引中排除。也就是說如
5、果某列存在空值,即使對該列建索引也不會提高性存在空值,即使對該列建索引也不會提高性能。能。任何在任何在where子句中使用子句中使用isnull或或isnotnull的語句優(yōu)化器是不允許使用索引的。的語句優(yōu)化器是不允許使用索引的。SQL語句編寫注意問題語句編寫注意問題 SQL語句編寫注意問題語句編寫注意問題 下面是一個(gè)采用聯(lián)接查詢的下面是一個(gè)采用聯(lián)接查詢的SQL語句,語句,select*fromemployswherefirst_name|last_name=BeillCliton;上面這條語句完全可以查詢出是否有上面這條語句完全可以查詢出是否有BillCliton這個(gè)員工,這個(gè)員工,但是這里
6、需要注意,系統(tǒng)優(yōu)化器對基于但是這里需要注意,系統(tǒng)優(yōu)化器對基于last_name創(chuàng)建的創(chuàng)建的索引沒有使用。當(dāng)采用下面這種索引沒有使用。當(dā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如何將返回的查詢?nèi)绾螌⒎祷?/p>
7、的查詢結(jié)果排序。結(jié)果排序。Orderby語句對要排序的列沒有什么語句對要排序的列沒有什么特別的限制,也可以將函數(shù)加入列中(象聯(lián)接或特別的限制,也可以將函數(shù)加入列中(象聯(lián)接或者附加等)。任何在者附加等)。任何在Orderby語句的非索引項(xiàng)或語句的非索引項(xiàng)或者有計(jì)算表達(dá)式都將降低查詢速度。者有計(jì)算表達(dá)式都將降低查詢速度。仔細(xì)檢查仔細(xì)檢查orderby語句以找出非索引項(xiàng)或者表達(dá)語句以找出非索引項(xiàng)或者表達(dá)式,它們會降低性能。解決這個(gè)問題的辦法就是式,它們會降低性能。解決這個(gè)問題的辦法就是重寫重寫orderby語句以使用索引,也可以為所使用語句以使用索引,也可以為所使用的列建立另外一個(gè)索引,同時(shí)應(yīng)絕對避
8、免在的列建立另外一個(gè)索引,同時(shí)應(yīng)絕對避免在orderby子句中使用表達(dá)式。子句中使用表達(dá)式。SQL語句編寫注意問題語句編寫注意問題 SQL語句編寫注意問題語句編寫注意問題 再看下面這個(gè)例子:再看下面這個(gè)例子:select*fromemployeewheresalary3000;對這個(gè)查詢,可以改寫為不使用對這個(gè)查詢,可以改寫為不使用NOT:select*fromemployeewheresalary3000;雖然這兩種查詢的結(jié)果一樣,但是第二種查雖然這兩種查詢的結(jié)果一樣,但是第二種查詢方案會比第一種查詢方案更快些。第二種詢方案會比第一種查詢方案更快些。第二種查詢允許查詢允許Oracle對對salary列使用索引,而第列使用索引,而第一種查詢則不能使用索引。一種查詢則不能使用索引。SQL語句編寫注意問題語句編寫注意問題 SQL語句編寫注意問題語句編寫注意問題 第二種格式中,子查詢以第二種格式中,子查詢以select*開始。運(yùn)開始。運(yùn)用用EXISTS子句不管子查詢從表中抽取什么數(shù)子句不管子查詢從表中抽取什么數(shù)據(jù)它只查看據(jù)它只查看where子句。這樣優(yōu)化器就不必遍子句。這樣優(yōu)化器就不必遍歷整個(gè)表而僅根據(jù)索引就可完成工作(這里假歷整個(gè)表而僅根據(jù)索引就可完成工作(這里假定在定在where語
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 農(nóng)副產(chǎn)品購銷示范合同
- 簽訂的門面租賃合同條款解析
- 建筑項(xiàng)目施工合同管理人員聘用合同
- 炒股合作經(jīng)典合同案例
- 車輛采購合同細(xì)則
- 國際物流服務(wù)合同專業(yè)版詳解
- 農(nóng)村土地流轉(zhuǎn)授權(quán)合同書
- 城市房屋拆遷補(bǔ)償安置標(biāo)準(zhǔn)合同樣本
- 鋼材買賣合同(示范文本GF-0155)
- 委托代理合同(普通1)
- 骶髂關(guān)節(jié)損傷郭倩課件
- 內(nèi)科學(xué)疾病概要-支氣管擴(kuò)張課件
- 2025陜西渭南光明電力集團(tuán)限公司招聘39人易考易錯(cuò)模擬試題(共500題)試卷后附參考答案
- 教學(xué)課件-電力系統(tǒng)的MATLAB-SIMULINK仿真與應(yīng)用(王晶)
- 2024年南京旅游職業(yè)學(xué)院高職單招語文歷年參考題庫含答案解析
- 《電商直播》 課件 項(xiàng)目一 走入電商直播
- 《中國宮腔鏡診斷與手術(shù)臨床實(shí)踐指南(2023版)》解讀課件
- 中藥學(xué)電子版教材
- GB/T 9535-1998地面用晶體硅光伏組件設(shè)計(jì)鑒定和定型
- 建筑公司項(xiàng)目部績效考核管理制度
- 中藥知識文庫:天麻形態(tài)學(xué)
評論
0/150
提交評論