在實際項目中,當數據庫的數據達到千萬級別時候,普通查詢效率直線下降,而且當使用的where條件較多,其查詢效率是讓人無法容忍的。假如一個taobao訂單查詢詳情要幾十秒,可想而知的用戶體驗是多差。
下面是一些優化方法:
一、數據庫設計方面
1、對查詢進行優化,應盡量避免全表掃描,首先應考慮在 where
及 order by
涉及的列上建立索引;
2、應盡量避免在 where 子句中對字段進行 null 值判斷,否則將導致引擎放棄使用索引而進行全表掃描,如: select id from t where num is null
可以在num上設置默認值0,確保表中num列沒有null值,然后這樣查詢: select id from t where num = 0;
3、并不是所有索引對查詢都有效,SQL是根據表中數據來進行查詢優化的,當索引列有大量數據重復時,查詢可能不會去利用索引,如一表中有字段sex,male、female幾乎各一半,那么即使在sex上建了索引也對查詢效率起不了作用;
4、索引并不是越多越好,索引固然可以提高相應的 select
的效率,但同時也降低了 insert
及 update
的效率,因為 insert
或 update
時有可能會重建索引,所以怎樣建索引需要慎重考慮,視具體情況而定。一個表的索引數最好不要超過6個,若太多則應考慮一些不常使用到的列上建的索引是否有必要;
5、應盡可能的避免更新索引數據列,因為索引數據列的順序就是表記錄的物理存儲順序,一旦該列值改變將導致整個表記錄的順序的調整,會耗費相當大的資源。若應用系統需要頻繁更新索引數據列,那么需要考慮是否應將該索引建為索引;
6、盡量使用數字型字段,若只含數值信息的字段盡量不要設計為字符型,這會降低查詢和連接的性能,并會增加存儲開銷。這是因為引擎在處理查詢和連接時會逐個比較字符串中每一個字符,而對于數字型而言只需要比較一次就夠了;
7、盡可能的使用 varchar/nvarchar
代替 char/nchar
,因為首先變長字段存儲空間小,可以節省存儲空間,其次對于查詢來說,在一個相對較小的字段內搜索效率顯然要高些;
8、盡量使用表變量來代替臨時表。如果表變量包含大量數據,請注意索引非常有限(只有主鍵索引);
9、避免頻繁創建和刪除臨時表,以減少系統表資源的消耗;
10、臨時表并不是不可使用,適當地使用它們可以使某些例程更有效,例如,當需要重復引用大型表或常用表中的某個數據集時。但是,對于一次性事件,最好使用導出表;
11、在新建臨時表時,如果一次性插入數據量很大,那么可以使用 select into
代替 create table
,避免造成大量 log ,以提高速度;如果數據量不大,為了緩和系統表的資源,應先create table
,然后insert
;
12、如果使用到了臨時表,在存儲過程的最后務必將所有的臨時表顯式刪除,先 truncate table
,然后 drop table
,這樣可以避免系統表的較長時間鎖定。
二、SQL語句方面
1、應盡量避免在 where
子句中使用!=
或<>
操作符,否則將引擎放棄使用索引而進行全表掃描;
2、應盡量避免在 where
子句中使用 or
來連接條件,否則將導致引擎放棄使用索引而進行全表掃描,如: select id from t where num=10 or num=20
可以這樣查詢: select id from t where num=10 union all select id from t where num=20;
3、in
和 not in
也要慎用,否則會導致全表掃描,如: select id from t where num in(1,2,3)
對于連續的數值,能用 between
就不要用 in
了: select id from t where num between 1 and 3;
4、下面的查詢也將導致全表掃描: select id from t where name like ‘%abc%'
5、如果在 where 子句中使用參數,也會導致全表掃描。因為SQL只有在運行時才會解析局部變量,但優化程序不能將訪問計劃的選擇推遲到運行時;它必須在編譯時進行選擇。然而,如果在編譯時建立訪問計劃,變量的值還是未知的,因而無法作為索引選擇的輸入項。如下面語句將進行全表掃描: select id from t where num=@num
可以改為強制查詢使用索引: select id from t with(index(索引名)) where num=@num
;
6、應盡量避免在 where
子句中對字段進行表達式操作,這將導致引擎放棄使用索引而進行全表掃描。如: select id from t where num/2=100
應改為: select id from t where num=100*2
;
7、應盡量避免在where
子句中對字段進行函數操作,這將導致引擎放棄使用索引而進行全表掃描。如: select id from t where substring(name,1,3)='abc'亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
色综合天天综合网国产成人网|
欧美综合激情网|
精品无人区乱码1区2区3区在线|
国产精品免费久久久久久|
午夜精品福利电影|
欧美日韩国产中文字幕|
中文字幕亚洲一区二区三区|
日本精品在线视频|
欧美性资源免费|
久久久久久久久久国产精品|
久久久在线免费观看|
亚洲国产精品va在线观看黑人|
精品国产91久久久久久老师|
亚洲成人久久久久|
日本19禁啪啪免费观看www|
欧美国产日韩免费|
国产精品99久久99久久久二8|
亚洲欧美制服另类日韩|
国产精品av在线|
69久久夜色精品国产69乱青草|
国产成人一区二区|
成人免费看吃奶视频网站|
欧美亚洲激情在线|
国内外成人免费激情在线视频|
精品一区二区三区四区在线|
91av视频在线免费观看|
中文字幕日韩免费视频|
国产精品欧美亚洲777777|
亚洲欧美日韩国产精品|
国产中文欧美精品|
国产精品 欧美在线|
日韩在线免费视频观看|
亚洲人成绝费网站色www|
亚洲欧美精品在线|
精品国产一区二区三区久久久|
亚洲图中文字幕|
亚洲欧洲美洲在线综合|
精品无人区乱码1区2区3区在线|
国产乱人伦真实精品视频|
亚洲偷熟乱区亚洲香蕉av|
国产日韩欧美视频在线|
久久的精品视频|
在线成人一区二区|
中文字幕少妇一区二区三区|
欧美黄色片视频|
欧美在线视频导航|
国产精品久久久久av|
成人黄色免费在线观看|
zzijzzij亚洲日本成熟少妇|
亚洲天堂av在线免费观看|
国产精品久久久久久av福利软件|
久久久女人电视剧免费播放下载|
91精品啪aⅴ在线观看国产|
国产亚洲精品久久久|
国产成人久久久精品一区|
国产不卡精品视男人的天堂|
激情av一区二区|
91亚洲精品一区|
久久不射热爱视频精品|
精品国产一区二区三区在线观看|
www.欧美精品|
最好看的2019的中文字幕视频|
国产成人精品一区二区在线|
亚洲一级一级97网|
久久视频免费观看|
欧美大尺度在线观看|
北条麻妃久久精品|
欧美激情第三页|
欧美日韩国产成人在线观看|
久久久久久久久爱|
欧美成年人在线观看|
欧美亚洲国产精品|
午夜精品视频网站|
国产欧美日韩最新|
亚洲日本中文字幕|
欧美乱妇高清无乱码|
亚洲激情久久久|
亚洲一区二区国产|
久久国产一区二区三区|
91在线视频成人|
国产午夜精品美女视频明星a级|
国产亚洲人成网站在线观看|
久久精品中文字幕免费mv|
欧美第一黄网免费网站|
国产精品久久久久久久电影|
国产精品美女www爽爽爽视频|
精品中文字幕在线观看|
欧美精品免费在线观看|
97视频免费在线看|
欧美情侣性视频|
久久久久久亚洲精品|
国产精品第一页在线|
欧美激情综合色综合啪啪五月|
国产精品日韩电影|
精品国产一区二区三区在线观看|
精品视频—区二区三区免费|
亚洲精品黄网在线观看|
日韩av黄色在线观看|
欧美日韩第一页|
成人在线观看视频网站|
欧美在线视频免费播放|
国产三级精品网站|
国产精品电影在线观看|
国产日韩在线精品av|
高清视频欧美一级|
青草成人免费视频|
亚洲二区在线播放视频|
亚洲视频综合网|
国产视频一区在线|
欧美日韩亚洲网|
亚洲福利精品在线|
色妞在线综合亚洲欧美|
中文字幕精品一区久久久久|
精品少妇一区二区30p|
亚洲第一区第一页|
97超碰蝌蚪网人人做人人爽|
国产女人精品视频|
亚洲成人久久久|
亚洲精品视频在线观看视频|
92福利视频午夜1000合集在线观看|
欧美高清视频一区二区|
欧美精品videosex极品1|
亚洲国产91精品在线观看|
黑人欧美xxxx|
日韩精品中文字幕有码专区|
日韩大陆毛片av|
最近2019年手机中文字幕|
欧美日韩在线一区|
91精品视频播放|
久久久久久网址|
懂色av影视一区二区三区|
国产啪精品视频|
午夜精品在线视频|
国产中文欧美精品|
欧美成人免费观看|
高清一区二区三区四区五区|
日韩av日韩在线观看|
最近2019中文字幕第三页视频|
国产亚洲成精品久久|
国产精品久久久久免费a∨大胸|
亚洲国产精品女人久久久|
久久久久久久久国产精品|
欧美大片网站在线观看|
久久久久女教师免费一区|
国产欧美欧洲在线观看|
国产精品自产拍高潮在线观看|
欧美性做爰毛片|
97在线精品国自产拍中文|
亚洲国产精品999|
国产ts一区二区|
国产91精品久|
91麻豆国产精品|
91国内产香蕉|
国产97人人超碰caoprom|
欧美另类交人妖|
国产日韩欧美日韩大片|
亚洲另类xxxx|
国产精品嫩草影院一区二区|
国产精品一区二区三区久久|
国产亚洲一区精品|
国产香蕉精品视频一区二区三区|
亚洲a一级视频|
国产精品久久久久久久久久三级|
久久天天躁日日躁|