自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Oracle SQL語(yǔ)句優(yōu)化的相關(guān)技術(shù)分析

運(yùn)維 數(shù)據(jù)庫(kù)運(yùn)維 Oracle
ORACLE試圖將其轉(zhuǎn)換成多個(gè)表的連接,如果轉(zhuǎn)換不成功則先執(zhí)行IN里面的子查詢,再查詢外層的表記錄,如果轉(zhuǎn)換成功則直接采用多個(gè)表的連接方式查詢。由此可見(jiàn)用IN的SQL至少多了一個(gè)轉(zhuǎn)換的過(guò)程。

IN 操作符

用IN寫(xiě)出來(lái)的SQL的優(yōu)點(diǎn)是比較容易寫(xiě)及清晰易懂,這比較適合現(xiàn)代軟件開(kāi)發(fā)的風(fēng)格。

但是用IN的SQL性能總是比較低的,從ORACLE執(zhí)行的步驟來(lái)分析用IN的SQL與不用IN的SQL有以下區(qū)別:

ORACLE試圖將其轉(zhuǎn)換成多個(gè)表的連接,如果轉(zhuǎn)換不成功則先執(zhí)行IN里面的子查詢,再查詢外層的表記錄,如果轉(zhuǎn)換成功則直接采用多個(gè)表的連接方式查詢。由此可見(jiàn)用IN的SQL至少多了一個(gè)轉(zhuǎn)換的過(guò)程。一般的SQL都可以轉(zhuǎn)換成功,但對(duì)于含有分組統(tǒng)計(jì)等方面的SQL就不能轉(zhuǎn)換了。

推薦方案:在業(yè)務(wù)密集的SQL當(dāng)中盡量不采用IN操作符。

NOT IN操作符

此操作是強(qiáng)列推薦不使用的,因?yàn)樗荒軕?yīng)用表的索引。

推薦方案:用NOT EXISTS 或(外連接+判斷為空)方案代替

  <> 操作符(不等于)

不等于操作符是永遠(yuǎn)不會(huì)用到索引的,因此對(duì)它的處理只會(huì)產(chǎn)生全表掃描。

推薦方案:用其它相同功能的操作運(yùn)算代替,如

a<>0 改為 a>0 or a<0

a<>’’ 改為 a>’’

IS NULL 或IS NOT NULL操作(判斷字段是否為空)

判斷字段是否為空一般是不會(huì)應(yīng)用索引的,因?yàn)锽樹(shù)索引是不索引空值的。

推薦方案:

用其它相同功能的操作運(yùn)算代替,如

a is not null 改為 a>0 或a>’’等。

不允許字段為空,而用一個(gè)缺省值代替空值,如業(yè)擴(kuò)申請(qǐng)中狀態(tài)字段不允許為空,缺省為申請(qǐng)。

建立位圖索引(有分區(qū)的表不能建,位圖索引比較難控制,如字段值太多索引會(huì)使性能下降,多人更新操作會(huì)增加數(shù)據(jù)塊鎖的現(xiàn)象)

> 及 < 操作符(大于或小于操作符)

大于或小于操作符一般情況下是不用調(diào)整的,因?yàn)樗兴饕蜁?huì)采用索引查找,但有的情況下可以對(duì)它進(jìn)行優(yōu)化,如一個(gè)表有100萬(wàn)記錄,一個(gè)數(shù)值型字段A,30萬(wàn)記錄的A=0,30萬(wàn)記錄的A=1,39萬(wàn)記錄的A=2,1萬(wàn)記錄的A=3。那么執(zhí)行A>2與A>=3的效果就有很大的區(qū)別了,因?yàn)锳>2時(shí)ORACLE會(huì)先找出為2的記錄索引再進(jìn)行比較,而A>=3時(shí)ORACLE則直接找到=3的記錄索引。

LIKE操作符

LIKE操作符可以應(yīng)用通配符查詢,里面的通配符組合可能達(dá)到幾乎是任意的查詢,但是如果用得不好則會(huì)產(chǎn)生性能上的問(wèn)題,如LIKE ‘%5400%’ 這種查詢不會(huì)引用索引,而LIKE ‘X5400%’則會(huì)引用范圍索引。一個(gè)實(shí)際例子:用YW_YHJBQK表中營(yíng)業(yè)編號(hào)后面的戶標(biāo)識(shí)號(hào)可來(lái)查詢營(yíng)業(yè)編號(hào) YY_BH LIKE ‘%5400%’ 這個(gè)條件會(huì)產(chǎn)生全表掃描,如果改成YY_BH LIKE ’X5400%’ OR YY_BH LIKE ’B5400%’ 則會(huì)利用YY_BH的索引進(jìn)行兩個(gè)范圍的查詢,性能肯定大大提高。

【編輯推薦】

  1. 云數(shù)據(jù)庫(kù)技術(shù)漸熱 各廠商上演多方斗法
  2. 甲骨文推出Oracle托管型CRM R16新功能
  3. Oracle數(shù)據(jù)庫(kù)中段管理的四個(gè)技巧
責(zé)任編輯:彭凡 來(lái)源: IT專(zhuān)家網(wǎng)論壇
相關(guān)推薦

2010-04-12 10:53:07

Oracle SQL

2010-04-26 14:32:21

Oracle SQL

2010-04-13 15:04:16

Oracle優(yōu)化

2009-11-16 13:47:35

Oracle SQL語(yǔ)

2010-04-20 15:58:15

Oracle 語(yǔ)句

2010-04-01 13:55:50

Oracle復(fù)制表

2011-05-20 15:59:06

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

2010-04-13 15:14:31

Oracle優(yōu)化

2017-08-07 15:52:33

Oracleonnect by優(yōu)化

2011-08-18 14:25:26

OracleEXPLAIN PLA

2010-10-29 10:22:21

Oracle表空間

2010-09-28 14:06:43

Sql Server表

2011-03-31 11:14:51

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

2010-04-15 16:36:13

Oracle SQL

2010-04-20 15:22:34

Oracle SQL

2010-04-29 14:06:40

Oracle SQL

2009-01-14 09:28:12

OracleSQL10g

2010-04-12 14:22:13

Oracle性能sql語(yǔ)句

2011-08-09 17:48:54

Oracle參數(shù)文件

2010-04-15 16:16:33

Oracle SQL
點(diǎn)贊
收藏

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