sql調(diào)優(yōu)的幾種方式小結(jié)
sql調(diào)優(yōu)的幾種方式:避免使用select *、用union all 代替union、小表驅(qū)動(dòng)大表、批量操作、多用limit、in中值太多、增量查詢、高效的分頁、用鏈接查詢代替子查詢、join數(shù)量不宜過多、join時(shí)需要注意、控制索引的數(shù)量、選擇合理的字段類型、提升group by的效率、索引優(yōu)化。
1、避免使用select *
select *會(huì)查詢所以字段,實(shí)際業(yè)務(wù)場(chǎng)景中不需要所有的字段,可以不進(jìn)行查詢。
2、用union all 代替union
union會(huì)排重,排重過程需要遍歷,排序,比較,更消耗cpu資源。在確定唯一,沒有重復(fù)數(shù)據(jù)的情況下,盡量用用union all。
3、小表驅(qū)動(dòng)大表
in 的話里面驅(qū)動(dòng)外面,in適合里子查詢是小表
exist 的話外面驅(qū)動(dòng)里面,適合外面是小表
4、批量插入
當(dāng)然一次插入量也不能太大,可以分批插入。
5、使用limit
在不需要獲取全部記錄的情況下,使用limit獲取指定數(shù)量。
6、in中值太多
查詢出來數(shù)量太大,限制一次最大查詢條數(shù)
還可以,多線程查詢,最后把查詢出來的數(shù)據(jù)匯總。
7、增量查詢
select name,age from user where id>#{lastId} limit 100;
查詢比上次id 大的100條
8、高效的分頁
select id,name,age from user limit 10000, 20;
mysql會(huì)查詢10020條,然后丟棄前面10000條,這個(gè)比較浪費(fèi)資源
可以優(yōu)化:
select id,name,age from user id>10000 limit 20;
找到上次分頁最大id
假如id是連續(xù)的,并且有序,可以用between
注意: between要在唯一索引上分頁,不然會(huì)出現(xiàn)每頁大小不一致問題。
9、用連接查詢代替子查詢
MySQL如果需要在兩張以上表中查詢數(shù)據(jù)的話,一般有兩種實(shí)現(xiàn)方式
子查詢
連接查詢
select * from order where user_id in (select id from user where name='vie');
子查詢可以通過in實(shí)現(xiàn),優(yōu)點(diǎn):這樣簡(jiǎn)單,
但缺點(diǎn)是,MySQL執(zhí)行子查詢時(shí),需要?jiǎng)?chuàng)建臨時(shí)表,查詢完成后再刪除臨時(shí)表,有一些額外開銷。
可以改成連接查詢:
select o.* from order o inner join user u on o.user_id = u.id where u.name='vie';
10、join表不宜過多
join表不宜超過3個(gè),如果join太多,MySQL在選擇索引時(shí)會(huì)非常復(fù)雜,很容易選錯(cuò)索引。
并且沒有命中,nested loop join 就會(huì)分別從兩個(gè)表讀一行數(shù)據(jù)進(jìn)行對(duì)比,時(shí)間復(fù)雜度n^2。
11、join時(shí)需要注意
join用的最多的時(shí)left join 和 inner join
left join:兩個(gè)表的交集和左表的剩余數(shù)據(jù)
inner join:兩個(gè)表的交集
inner join mysql會(huì)自動(dòng)選擇小表驅(qū)動(dòng),
left join 左邊的表驅(qū)動(dòng)右邊的表
12、控制索引數(shù)量
索引不是越多越好,索引需要額外的存儲(chǔ)空間,B+樹保存索引,額外的性能消耗。
單表索引數(shù)量盡量控制在5個(gè)以內(nèi),且單個(gè)索引字段數(shù)量控制在5個(gè)以內(nèi)。
13、選擇合理的字段類型
能用數(shù)字類型就不用字符串,字符串處理速度比數(shù)字類型慢
14、提升group by效率
主要功能去重,分組
先過濾數(shù)據(jù),減少數(shù)據(jù),再分組
select id, name ,age from user group by id having id <50;
這種寫法就不好,建議以下寫法:
select id, name ,age from user where id <50 group by id;
15、索引優(yōu)化
強(qiáng)制走哪個(gè)索引
select * from user force index(索引)
到此這篇關(guān)于sql調(diào)優(yōu)的幾種方式小結(jié)的文章就介紹到這了,更多相關(guān)sql調(diào)優(yōu)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
sqlserver利用存儲(chǔ)過程去除重復(fù)行的sql語句
以前弄過類似,去除相同信息的方法,現(xiàn)在找不到了,不過今天又花一些時(shí)間給弄出來了,記錄一下2010-06-06SQL實(shí)現(xiàn)遞歸及存儲(chǔ)過程中In()參數(shù)傳遞解決方案詳解
這篇文章詳細(xì)介紹了SQL實(shí)現(xiàn)遞歸及存儲(chǔ)過程中In()參數(shù)傳遞解決方案,有需要的朋友可以參考一下2013-09-09SQL Server判斷數(shù)據(jù)庫、表、列、視圖、存儲(chǔ)過程、函數(shù)是否存在總結(jié)
這篇文章主要介紹了SQL Server判斷數(shù)據(jù)庫、表、列、視圖、存儲(chǔ)過程、函數(shù)是否存在,本文是一篇總結(jié)篇,結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-05-05淺談mssql access數(shù)據(jù)庫 top分頁方法
雙top法相比于not in和max法,就是可以傳入一條sql語句來生成分頁sql語句,也可多字段排序2013-10-10SQL Server中調(diào)用C#類中的方法實(shí)例(使用.NET程序集)
這篇文章主要介紹了SQL Server中調(diào)用C#類中的方法實(shí)例(使用.NET程序集),本文實(shí)現(xiàn)了在SQL Server中調(diào)用C#寫的類及方法,需要的朋友可以參考下2014-10-10使用sp_xml_preparedocument處理XML文檔的方法
有時(shí)會(huì)在存儲(chǔ)過程中處理一些XML格式的數(shù)據(jù),所以會(huì)用到sp_xml_preparedocument,他可以將XML數(shù)據(jù)進(jìn)行讀取,然后使用 MSXML 分析器 (Msxmlsql.dll) 對(duì)其進(jìn)行分析。2011-08-08sql清空表數(shù)據(jù)后重新添加數(shù)據(jù)存儲(chǔ)過程的示例
這篇文章主要介紹了sql清空表數(shù)據(jù)后重新添加數(shù)據(jù)存儲(chǔ)過程的示例,需要的朋友可以參考下2014-04-04SQL Server 置疑、可疑、正在恢復(fù)等情況分析
有些時(shí)候當(dāng)你重啟了數(shù)據(jù)庫服務(wù),會(huì)發(fā)現(xiàn)有些數(shù)據(jù)庫變成了正在恢復(fù)、置疑、可疑等情況,這個(gè)時(shí)候DBA就會(huì)很緊張了,下面是一些在實(shí)踐中得到證明的方法2011-12-12