MySQL 分頁查詢效能分析

2021-07-04 15:22:13 字數 1149 閱讀 3626

mysql分頁查詢   今天研究了一下mysql的分頁查詢,記錄並分享如下:         

方式1:

select * from table order by id limit m, n;          

該語句的意思為,查詢m+n條記錄,去掉前m條,返回後n條記錄。無疑該查詢能夠實現分頁功能,但是如果m的值越大,查詢的效能會越低(越後面的頁數,查詢效能越低),因為mysql同樣需要掃瞄過m+n條記錄。

方式2:

select * from table where id > #max_id# order by id limit n;        

方式3:

為了避免能夠實現方式2不能實現的查詢,就同樣需要使用到limit m, n子句,為了效能,就需要將m的值盡力的小,比如當前在第3頁,

需要查詢第5頁,每頁10條資料,當前第3頁的最大id為#max_id#:        

select * from table where id > #max_id# order by id limit 20, 10;         

其實該查詢方式是部分解決了方式2的問題,但如果當前在第2頁,需要查詢第100頁或1000頁,效能仍然會較差。   

方式4:

select * from table as a inner join (select id from table order by id limit m, n) as b on a.id = b.id order by a.id;         

該查詢同方式1一樣,m的值可能很大,但由於內部的子查詢只掃瞄了字段id,而不是整張表,所以效能要強於方式1查詢,並且該查詢能夠解決方式2和方式3不能解決的問題。          

方式5:

select * from table where id > (select id from table order by id limit m, 1) limit n;        

該查詢方式同方式4,同樣通過子查詢掃瞄欄位id,效果同方式4。至於效能的話,方式5的效能會略好於方式4,因為方式5不需要在進行表的關聯,而是乙個簡單的比較。 

**:

MySQL的limit分頁查詢的效能分析及優化

select from table a limit m,n limit 子句可以被用於強制 select 語句返回指定的記錄數。limit 接受乙個或兩個數字引數。引數必須是乙個整數常量。如果給定兩個引數,第乙個引數指定第乙個返回記錄行的偏移量,第二個引數指定返回記錄行的最大數目。初始記錄行的偏移量...

sqlserver分頁查詢語句效能分析

目的 通過三種不同的分頁查詢語句的寫法來比較其效能。環境 windows server 2003 sp2 sqlserver2008。資料準備 100萬條資料。說明 下列sql語句中 pagesize表明每頁記錄條數 pageindex表示頁碼 table表示表明,id表示table表中的主鍵。方法...

MySQL查詢效能分析

剖析伺服器負載方法 步驟 1 捕獲mysql的查詢到日誌檔案,建議使用慢查詢日誌 2 根據查詢日誌生產剖析報告,利用pt query digest可將日誌生成報告。根據上述方法可以定位到比較慢的sql,進行單條查詢問題剖析 剖析單條查詢 使用show profile測量語句耗費的時間 得到具體的慢查...