玩家必看科普!麻豆人人妻人人妻人人片AV,欧美老妇交乱视频在线观看,久久综合九色综合久99_知乎
<ruby id="fgcka"></ruby>
  • <progress id="fgcka"></progress>
    <tbody id="fgcka"></tbody>
    <dd id="fgcka"></dd>

    1. <dd id="fgcka"></dd>

      <em id="fgcka"></em>
        1. 系統城裝機大師 - 固鎮縣祥瑞電腦科技銷售部宣傳站!

          當前位置:首頁 > 數據庫 > Mysql > 詳細頁面

          order by + limit分頁時數據重復問題及解決方法

          時間:2023-03-19來源:系統城裝機大師作者:佚名

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

          1
          2
          3
          4
          5
          6
          7
          8
          9
          10
          11
          12
          13
          14
          15
          16
          17
          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分頁查詢

          查詢第1頁

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

          查詢第2頁

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

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

          原因分析:

          查看以上語句的執行計劃

          可以看到,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加上主鍵約束,排序字段添加索引

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

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

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

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

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

          分頁問題

          分頁重復的問題

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

          分享到:

          相關信息

          • Mysql存儲二進制對象數據問題

            Mysql存儲二進制對象數據 首先數據庫存儲一個Object對象 與數據庫對應的實體類 編寫一個操作二進制的工具類 Mysql存儲二進制大型對象類型對照 MySql MediumBlob——MySql的Bolb四種類型...

            2023-03-15

          • MySQL5.7升級MySQL8.0的完整卸載與安裝及連接Navicat的步驟

            1、卸載MySQL5.7.24 1.備份整個數據庫文件 2.停止MySQL服務 3.控制面板卸載程序 4.刪除系統隱藏文件夾中的相應目錄 5.清理注冊表 2、安裝MySQL8.0.28 3、連接Navicat...

            2023-03-15

          系統教程欄目

          欄目熱門教程

          人氣教程排行

          站長推薦

          熱門系統下載

          玩家必看科普!麻豆人人妻人人妻人人片AV,欧美老妇交乱视频在线观看,久久综合九色综合久99_知乎 人人玩人人添人人澡超碰偷拍 青春娱乐视频精品分类官网2 最好最新高清中文字幕 91国自产拍最新2018 欧美精品一区二区三区不卡网 深夜你懂得我的意思2021 宿舍NP乖把腿张开H 网恋奔现一天被要几次 为什么我越叫他越快 学渣各种各样的PLAY 英语课代表下面好软小说 亚洲国产综合在线区尤物 FREE性丰满HD性欧美 我年轻漂亮的继坶BD 最近中文字幕完整免费视频 啦啦啦免费视频卡一卡二 青柠视频在线观看大全 在线天堂WWW在线资源 亚洲国产日本韩国欧美MV 天天学习|久久久久久久精品国产亚洲87 国产K频道分享系统进入口 三个嘴都吃满了还塞满了 JAPONENSIS老师学生JAVAHBB 亚洲精品1卡2卡3卡4卡 樱花草在线社区WWW韩国 好涨水快流出来了快吃动视频 久久AV无码精品人妻出轨