亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MySQL中怎樣實現分頁查詢操作

發布時間:2021-08-13 17:10:55 來源:億速云 閱讀:156 作者:Leah 欄目:數據庫

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;

        該查詢每次會返回n條記錄,卻無需像方式1掃描過m條記錄,在大數據量的分頁情況下,性能可以明顯好于方式1,但該分頁查詢必須要每次查詢時拿到上一次查詢(上一頁)的一個最大id(或最小id)。該查詢的問題就在于,我們有時沒有辦法拿到上一次查詢(上一頁)的最大id(或最小id),比如當前在第3頁,需要查詢第5頁的數據,該查詢方法便愛莫能助了。
        方式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不需要在進行表的關聯,而是一個簡單的比較。

看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

庄河市| 高平市| 贺兰县| 株洲市| 舞钢市| 拜泉县| 航空| 昌宁县| 黄石市| 徐水县| 什邡市| 五大连池市| 湖口县| 铜梁县| 侯马市| 泰州市| 荥经县| 贵州省| 津南区| 富裕县| 垣曲县| 莫力| 绥滨县| 抚顺市| 邢台市| 呼伦贝尔市| 五河县| 营口市| 志丹县| 广东省| 余江县| 大兴区| 湄潭县| 凉城县| 岳池县| 肥西县| 建水县| 扎赉特旗| 万宁市| 图们市| 南涧|