MySQL實現(xiàn)分頁查詢

limit 基本實現(xiàn)方式

一般情況下,客戶端通過傳遞 pageNo(頁碼)、pageSize(每頁條數(shù))兩個參數(shù)去分頁查詢數(shù)據(jù)庫中的數(shù)據(jù),在數(shù)據(jù)量較小(元組百/千級)時使用 MySQL自帶的 limit 來解決這個問題:

收到客戶端{pageNo:1,pagesize:10}

select * from table limit (pageNo-1)*pageSize, pageSize;

收到客戶端{pageNo:5,pageSize:30}

select * from table limit (pageNo-1)*pageSize,pageSize;

建立主鍵或者唯一索引

在數(shù)據(jù)量較小的時候簡單的使用 limit 進行數(shù)據(jù)分頁在性能上面不會有明顯的緩慢,但是數(shù)據(jù)量達到了 萬級到百萬級 sql語句的性能將會影響數(shù)據(jù)的返回。這時需要利用主鍵或者唯一索引進行數(shù)據(jù)分頁;

假設(shè)主鍵或者唯一索引為 good_id

收到客戶端{pageNo:5,pagesize:10}

select * from table where good_id > (pageNo-1)*pageSize limit pageSize;

–返回good_id為40到50之間的數(shù)據(jù)

基于數(shù)據(jù)再排序

當(dāng)需要返回的信息為順序或者倒序時,對上面的語句基于數(shù)據(jù)再排序。order by ASC/DESC 順序或倒序 默認(rèn)為順序

select * from table where good_id > (pageNo-1)*pageSize order by good_id limit pageSize;

–返回good_id為40到50之間的數(shù)據(jù),數(shù)據(jù)依據(jù)good_id順序排列

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容