久久精品人人爽,华人av在线,亚洲性视频网站,欧美专区一二三

sql有哪些優(yōu)化方法

151次閱讀
沒有評論

共計(jì) 1317 個字符,預(yù)計(jì)需要花費(fèi) 4 分鐘才能閱讀完成。

自動寫代碼機(jī)器人,免費(fèi)開通

丸趣 TV 小編給大家分享一下 sql 有哪些優(yōu)化方法,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

1. 對查詢進(jìn)行優(yōu)化,應(yīng)盡量避免全表掃描,首先應(yīng)考慮在 where 及 order by 涉及的列上建立索引。

2. 應(yīng)盡量避免在 where 子句中對字段進(jìn)行 null 值判斷,否則將導(dǎo)致引擎放棄使用索引而進(jìn)行全表掃描,如:

select id from t where num is null

可以在 num 上設(shè)置默認(rèn)值 0,確保表中 num 列沒有 null 值,然后這樣查詢:

select id from t where num=0

3. 應(yīng)盡量避免在 where 子句中使用!= 或 操作符,否則將引擎放棄使用索引而進(jìn)行全表掃描。

4. 應(yīng)盡量避免在 where 子句中使用 or 來連接條件,否則將導(dǎo)致引擎放棄使用索引而進(jìn)行全表掃描,如:

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

5.in 和 not in 也要慎用,否則會導(dǎo)致全表掃描,如:

select id from t where num in(1,2,3)

對于連續(xù)的數(shù)值,能用 between 就不要用 in 了:

select id from t where num between 1 and 3

6. 下面的查詢也將導(dǎo)致全表掃描:

select id from t where name like  %abc%

7. 應(yīng)盡量避免在 where 子句中對字段進(jìn)行表達(dá)式操作,這將導(dǎo)致引擎放棄使用索引而進(jìn)行全表掃描。如:

select id from t where num/2=100

應(yīng)改為:

select id from t where num=100*2

8. 應(yīng)盡量避免在 where 子句中對字段進(jìn)行函數(shù)操作,這將導(dǎo)致引擎放棄使用索引而進(jìn)行全表掃描。如:

select id from t where substring(name,1,3)= abc --name 以 abc 開頭的 id

應(yīng)改為:

select id from t where name like  abc%

9. 不要在 where 子句中的“=”左邊進(jìn)行函數(shù)、算術(shù)運(yùn)算或其他表達(dá)式運(yùn)算,否則系統(tǒng)將可能無法正確使用索引。

10. 在使用索引字段作為條件時,如果該索引是復(fù)合索引,那么必須使用到該索引中的第一個字段作為條件時才能保證系統(tǒng)使用該索引,

否則該索引將不會被使用,并且應(yīng)盡可能的讓字段順序與索引順序相一致。

11. 不要寫一些沒有意義的查詢,如需要生成一個空表結(jié)構(gòu):

select col1,col2 into #t from t where 1=0

這類代碼不會返回任何結(jié)果集,但是會消耗系統(tǒng)資源的,應(yīng)改成這樣:

create table #t(...)

以上是“sql 有哪些優(yōu)化方法”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注丸趣 TV 行業(yè)資訊頻道!

向 AI 問一下細(xì)節(jié)

正文完
 
丸趣
版權(quán)聲明:本站原創(chuàng)文章,由 丸趣 2023-12-16發(fā)表,共計(jì)1317字。
轉(zhuǎn)載說明:除特殊說明外本站除技術(shù)相關(guān)以外文章皆由網(wǎng)絡(luò)搜集發(fā)布,轉(zhuǎn)載請注明出處。
評論(沒有評論)
主站蜘蛛池模板: 景洪市| 凤台县| 道孚县| 新宁县| 酒泉市| 木里| 修文县| 蒲江县| 乌兰浩特市| 陇西县| 油尖旺区| 荆门市| 清原| 衢州市| 新闻| 白山市| 巴东县| 手机| 收藏| 红桥区| 泰顺县| 大英县| 仁布县| 乐清市| 武川县| 伊金霍洛旗| 景德镇市| 成武县| 祁门县| 沈阳市| 泽普县| 札达县| 莱西市| 霍林郭勒市| 威宁| 临沂市| 昌图县| 涪陵区| 永和县| 叙永县| 张家口市|