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

Oracle SQL語句優(yōu)化的相關技術分析

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

IN 操作符

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

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

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

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

NOT IN操作符

此操作是強列推薦不使用的,因為它不能應用表的索引。

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

  <> 操作符(不等于)

不等于操作符是永遠不會用到索引的,因此對它的處理只會產生全表掃描。

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

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

a<>’’ 改為 a>’’

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

判斷字段是否為空一般是不會應用索引的,因為B樹索引是不索引空值的。

推薦方案:

用其它相同功能的操作運算代替,如

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

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

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

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

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

LIKE操作符

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

【編輯推薦】

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

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)化

2010-04-20 15:58:15

Oracle 語句

2009-11-16 13:47:35

Oracle SQL語

2010-04-01 13:55:50

Oracle復制表

2011-05-20 15:59:06

Oracle存儲Sql語句

2017-08-07 15:52:33

Oracleonnect by優(yōu)化

2010-04-13 15:14:31

Oracle優(yōu)化

2010-10-29 10:22:21

Oracle表空間

2011-08-18 14:25:26

OracleEXPLAIN PLA

2010-09-28 14:06:43

Sql Server表

2011-03-31 11:14:51

Sql語句優(yōu)化

2010-04-15 16:36:13

Oracle SQL

2010-04-15 16:16:33

Oracle SQL

2011-08-09 17:48:54

Oracle參數(shù)文件

2009-11-16 17:55:58

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
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产黄色在线观看 | 久久99久久98精品免观看软件 | 久久www免费人成看片高清 | 视频一区二区在线 | 婷婷开心激情综合五月天 | 亚洲精品视频在线 | 偷拍自拍网址 | 国产乱码精品一区二区三区中文 | 国产成人精品久久二区二区 | 久久国产欧美日韩精品 | 中文字幕国产日韩 | 国产视频中文字幕 | 国产精品免费一区二区三区四区 | 国产精品久久九九 | 亚洲一区在线日韩在线深爱 | 国产福利在线视频 | 国产免费自拍 | 国产精品免费在线 | 99久久成人 | 中文字幕在线观看国产 | 99re热精品视频国产免费 | 999热视频 | 成人精品国产免费网站 | 激情婷婷成人 | www.久久久久久久久久久久 | 午夜激情在线 | 罗宾被扒开腿做同人网站 | 久久在线看| 国产午夜精品视频 | 国产乱码久久久久久 | 久久综合久久久 | 欧美日韩精品一区二区天天拍 | 国产一区二区三区色淫影院 | 亚洲免费在线 | 日韩一区二区三区在线 | 国产精品国产精品国产专区不片 | 亚洲一区综合 | 午夜www | 国产特级毛片 | 亚洲精品电影 | 久久精品视频在线播放 |