日韩欧美人妻无码精品白浆,www.大香蕉久久网,狠狠的日狠狠的操,日本好好热在线观看

LOGO OA教程 ERP教程 模切知識(shí)交流 PMS教程 CRM教程 開發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

避免SQL全表查詢的方法介紹

admin
2014年12月1日 23:28 本文熱度 5031
我們知道,SQL查詢代碼務(wù)求簡潔高效,目的只有一個(gè)提高執(zhí)行效率,帶來優(yōu)良的用戶體驗(yàn),這其中之一就是要避免SQL全表查詢,請(qǐng)參考本文給出的具體分析與方法介紹吧。


1、模糊查詢效率很低:
  原因:like本身效率就比較低,應(yīng)該盡量避免查詢條件使用like;對(duì)于like ‘%...%’(全模糊)這樣的條件,是無法使用索引的,全表掃描自然效率很低;另外,由于匹配算法的關(guān)系,模糊查詢的字段長度越大,模糊查詢效率越低。


  解決辦法:首先盡量避免模糊查詢,如果因?yàn)闃I(yè)務(wù)需要一定要使用模糊查詢,則至少保證不要使用全模糊查詢,對(duì)于右模糊查詢,即like ‘…%’,是會(huì)使用索引的;左模糊like


  ‘%...’無法直接使用索引,但可以利用reverse + function index 的形式,變化成 like ‘…%’;全模糊是無法優(yōu)化的,一定要的話考慮用搜索引擎。出于降低數(shù)據(jù)庫服務(wù)器的負(fù)載考慮,盡可能地減少數(shù)據(jù)庫模糊查詢。


2、查詢條件中含有is null的select語句執(zhí)行慢
  原因:Oracle 9i中,查詢字段is null時(shí)單索引失效,引起全表掃描。


  解決方法:SQL語法中使用NULL會(huì)有很多麻煩,最好索引列都是NOT NULL的;對(duì)于is null,可以建立組合索引,nvl(字段,0),對(duì)表和索引analyse后,is null查詢時(shí)可以重新啟用索引查找,但是效率還不是值得肯定;is not null 時(shí)永遠(yuǎn)不會(huì)使用索引。一般數(shù)據(jù)量大的表不要用is null查詢。


3、查詢條件中使用了不等于操作符(<>、!=)的select語句執(zhí)行慢
  原因:SQL中,不等于操作符會(huì)限制索引,引起全表掃描,即使比較的字段上有索引


  解決方法:通過把不等于操作符改成or,可以使用索引,避免全表掃描。例如,把column<>’aaa’,改成column<’aaa’ or column>’aaa’,就可以使用索引了。


4、使用組合索引,如果查詢條件中沒有前導(dǎo)列,那么索引不起作用,會(huì)引起全表掃描;但是從Oracle9i開始,引入了索引跳躍式掃描的特性,可以允許優(yōu)化器使用組合索引,即便索引的前導(dǎo)列沒有出現(xiàn)在WHERE子句中。例如:create index skip1 on emp5(job,empno);   全索引掃描 select count(*) from emp5 where empno=7900;   索引跳躍式掃描 select /*+ index(emp5 skip1)*/ count(*) from emp5 where empno=7900; 前一種是全表掃描,后一種則會(huì)使用組合索引。


5、or語句使用不當(dāng)會(huì)引起全表掃描
  原因:where子句中比較的兩個(gè)條件,一個(gè)有索引,一個(gè)沒索引,使用or則會(huì)引起全表掃描。例如:where A=:1 or B=:2,A上有索引,B上沒索引,則比較B=:2時(shí)會(huì)重新開始全表掃描。


6、組合索引,排序時(shí)應(yīng)按照組合索引中各列的順序進(jìn)行排序,即使索引中只有一個(gè)列是要排序的,否則排序性能會(huì)比較差。例如:create index skip1 on emp5(job,empno,date);  select job,empno from emp5 where job=’manager’and empno=’10’ order by job,empno,date desc; 實(shí)際上只是查詢出符合job=’manager’and empno=’10’條件的記錄并按date降序排列,但是寫成order by date desc性能較差。


7、Update 語句,如果只更改1、2個(gè)字段,不要Update全部字段,否則頻繁調(diào)用會(huì)引起明顯的性能消耗,同時(shí)帶來大量日志。


8、對(duì)于多張大數(shù)據(jù)量(這里幾百條就算大了)的表JOIN,要先分頁再JOIN,否則邏輯讀會(huì)很高,性能很差。


9、select count(*) from table;這樣不帶任何條件的count會(huì)引起全表掃描,并且沒有任何業(yè)務(wù)意義,是一定要杜絕的。


10、sql的where條件要綁定變量,比如where column=:1,不要寫成where column=‘a(chǎn)aa’,這樣會(huì)導(dǎo)致每次執(zhí)行時(shí)都會(huì)重新分析,浪費(fèi)CPU和內(nèi)存資源。


該文章在 2014/12/1 23:28:01 編輯過
關(guān)鍵字查詢
相關(guān)文章
正在查詢...
點(diǎn)晴ERP是一款針對(duì)中小制造業(yè)的專業(yè)生產(chǎn)管理軟件系統(tǒng),系統(tǒng)成熟度和易用性得到了國內(nèi)大量中小企業(yè)的青睞。
點(diǎn)晴PMS碼頭管理系統(tǒng)主要針對(duì)港口碼頭集裝箱與散貨日常運(yùn)作、調(diào)度、堆場、車隊(duì)、財(cái)務(wù)費(fèi)用、相關(guān)報(bào)表等業(yè)務(wù)管理,結(jié)合碼頭的業(yè)務(wù)特點(diǎn),圍繞調(diào)度、堆場作業(yè)而開發(fā)的。集技術(shù)的先進(jìn)性、管理的有效性于一體,是物流碼頭及其他港口類企業(yè)的高效ERP管理信息系統(tǒng)。
點(diǎn)晴WMS倉儲(chǔ)管理系統(tǒng)提供了貨物產(chǎn)品管理,銷售管理,采購管理,倉儲(chǔ)管理,倉庫管理,保質(zhì)期管理,貨位管理,庫位管理,生產(chǎn)管理,WMS管理系統(tǒng),標(biāo)簽打印,條形碼,二維碼管理,批號(hào)管理軟件。
點(diǎn)晴免費(fèi)OA是一款軟件和通用服務(wù)都免費(fèi),不限功能、不限時(shí)間、不限用戶的免費(fèi)OA協(xié)同辦公管理系統(tǒng)。
Copyright 2010-2025 ClickSun All Rights Reserved

性生活视频网站在线观看| 黄片网站蜜桃| 天天操夜夜操不卡| …久久久久久久| 欧美色色图 久久| 婷婷婷久久| 熟妇人妻久久久| 大香蕉网大香蕉久久网| 亚洲精品视频污污视频在线观看| 黑人与韩日无码久久播| 又粗又长又黄到视频| 日本激情二级| 欧美日韩 偷拍自拍| 麻豆视频日韩精品| 黃色三級視頻| 欧美.日韩-区二区三区| 天天干天天射天天爽天天插| 无码熟妇人妻AV在线电影| 2020经典精品福利视频| 国产熟女一区二区三区视| 一本久黄片| 操日韩熟女视频| 国产人人肉| 日韩欧一道二区| 国产日本成人久久综合| 几把草女生逼的亚洲| 欧美高潮喷水自拍| 亚洲情侣免费观看| 亚洲国产乱码在线| 邪恶午夜影院| 女人激情久久免费| 色精品人妻色地址| 人妻在线播放不卡| 女生高潮国产视频| 美女上海高高潮黄色| 午夜伦理久久久久久久| 国产在线后入日韩| 亚洲操人日韩| 亚洲综合在线欧美专区在线| 欧美精品一级视频一区| 日本 欧美 视频 久久|