中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

order?by+limit分頁時數據重復問題如何解決

發布時間:2023-03-21 17:35:03 來源:億速云 閱讀:84 作者:iii 欄目:開發技術

本文小編為大家詳細介紹“order by+limit分頁時數據重復問題如何解決”,內容詳細,步驟清晰,細節處理妥當,希望這篇“order by+limit分頁時數據重復問題如何解決”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。

問題描述:MYSQL version 5.6.8command 表結構

CREATE TABLE

command

(

ID INT NOT NULL,

NAME VARCHAR(16),

DESCRIPTION VARCHAR(32),

INDEX idx_command_id (ID)

)

ENGINE=InnoDB DEFAULT CHARSET=utf8;

表數據

order?by+limit分頁時數據重復問題如何解決

order by + limit分頁查詢

查詢第1頁

select * from command order by age limit 0,4;

order?by+limit分頁時數據重復問題如何解決

查詢第2頁

select * from command order by age limit 4,4;

order?by+limit分頁時數據重復問題如何解決

可以看到第2頁中查出了第1頁中存在的重復數據

原因分析:

查看以上語句的執行計劃

order?by+limit分頁時數據重復問題如何解決

可以看到,order by limit時Mysql會進行優化,使用的是內存中的filesort文件排序,in memory filesort 使用的是優先級隊列(priority queue),優先級隊列使用的二叉堆;

使用 priority queue 的目的,就是在不能使用索引有序性的時候,如果要排序,并且使用了limit n,那么只需要在排序的過程中,保留n條記錄即可這樣雖然不能解決所有記錄都需要排序的開銷,但是只需要 sort buffer 少量的內存就可以完成排序。

因此,在limit n時,只會堆排序前n個,且是不穩定排序,因此并不能保證字段值相同時的相對順序,因此分頁時可能造成重復;

MySQL 5.5 沒有這個優化,所以也就不會出現這個問題,5.6版本之后才出現了這種情況。

解決方案:

1. 新加一個排序字段,這個字段絕對有序,在第1個排序字段重復時, 使用第2個字段排序

2. 利用索引的有序性,如給id加上主鍵約束,排序字段添加索引

explain select id,age from command order by age limit 4,4

order?by+limit分頁時數據重復問題如何解決

可以看到查詢走了索引,排序就穩定了,沒什么問題

(3)一些常見的數據庫排序問題

不加order by的時候的排序問題
用戶在使用Oracle或MySQL的時候,發現MySQL總是有序的,Oracle卻很混亂,這個主要是因為Oracle是堆表,MySQL是索引聚簇表的原因。

所以沒有order by的時候,數據庫并不保證記錄返回的順序性,并且不保證每次返回都一致的。

分頁問題

分頁重復的問題

如前面所描述的,分頁是在數據庫提供的排序功能的基礎上,衍生出來的應用需求,數據庫并不保證分頁的重復問題。

讀到這里,這篇“order by+limit分頁時數據重復問題如何解決”文章已經介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內容的文章,歡迎關注億速云行業資訊頻道。

向AI問一下細節

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

AI

镇沅| 临汾市| 芜湖市| 高雄市| 师宗县| 扶风县| 庆云县| 南汇区| 宁夏| 万山特区| 奈曼旗| 庆城县| 通化市| 福泉市| 蒲城县| 渭南市| 搜索| 长子县| 会昌县| 古丈县| 江孜县| 嵩明县| 黎川县| 荥阳市| 安义县| 通化县| 敦煌市| 西贡区| 高陵县| 麻城市| 辛集市| 古蔺县| 夏津县| 汽车| 宾阳县| 东山县| 微博| 正阳县| 丰原市| 庆云县| 特克斯县|