MySQL索引優(yōu)化之分頁探索詳細(xì)介紹
??MySQL??索引優(yōu)化之分頁探索
表結(jié)構(gòu)
CREATE TABLE `demo` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL DEFAULT '' COMMENT '姓名', `age` int(11) NOT NULL DEFAULT '0' COMMENT '年齡', `position` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL DEFAULT '' COMMENT '職位', `card_num` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci DEFAULT NULL COMMENT '工卡號', PRIMARY KEY (`id`), KEY `index_union` (`name`,`age`,`position`) ) ENGINE=InnoDB AUTO_INCREMENT=450003 DEFAULT CHARSET=utf8; 450003條數(shù)據(jù)
limit分頁執(zhí)行情況
像select * from demo limit 90000,10;考慮到回表,所以mysql干脆選擇全表掃描。
mysql不是直接從第90000行開始計算10條,而是從第一個葉子節(jié)點開始計數(shù),計算90010行。
案例一
針對上圖,當(dāng)id是連續(xù)自增的時候,可以用主鍵篩選出id=90000之后的數(shù)據(jù)。因為主鍵的索引是B+樹結(jié)構(gòu),本身就是有序的。
案例二
先按照name排序,然后再從第90000行起找10行,雖然name是索引,但select的列在index_union索引樹上并沒有保存。
所以還會涉及到回表,于是mysql直接選擇掃主鍵索引樹的葉子結(jié)點,先將40多萬數(shù)據(jù)根據(jù)name排好序,然后計算90000行+10行。
優(yōu)化方法:利用子查詢解決最消耗時間的排序和回表問題,聯(lián)合索引樹種保存有主鍵id,order by name的話可以將name、age、position整個索引充分使用因為確定了最左列的排序,其余的倆列age、和position其實也是
排好序的了,通過Extra字段也可以是使用了索引樹做排序。
最外層的查詢是根據(jù)主鍵來關(guān)聯(lián)的,所以幾乎可以忽略。10+10 因為id是主鍵,可以直接拿臨時表10條數(shù)據(jù)去掃。
到此這篇關(guān)于MySQL索引優(yōu)化之分頁探索詳細(xì)介紹的文章就介紹到這了,更多相關(guān)MySQL分頁探索內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
抽取oracle數(shù)據(jù)到mysql數(shù)據(jù)庫的實現(xiàn)過程
今天小編就為大家分享一篇關(guān)于抽取oracle數(shù)據(jù)到mysql數(shù)據(jù)庫的實現(xiàn)過程,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2019-02-02mysql數(shù)據(jù)庫插入速度和讀取速度的調(diào)整記錄
由于項目變態(tài)需求;需要在一個比較短時間段急劇增加數(shù)據(jù)庫記錄(兩三天內(nèi),由于0增加至4億)。在整個過程調(diào)優(yōu)過程非常艱辛2012-07-07MySQL與PHP的基礎(chǔ)與應(yīng)用專題之?dāng)?shù)據(jù)控制
MySQL是一個關(guān)系型數(shù)據(jù)庫管理系統(tǒng),由瑞典MySQL?AB?公司開發(fā),屬于?Oracle?旗下產(chǎn)品。MySQL?是最流行的關(guān)系型數(shù)據(jù)庫管理系統(tǒng)之一,本系列將帶你掌握php與mysql的基礎(chǔ)應(yīng)用,本篇帶你了解數(shù)據(jù)控制2022-02-02Mysql批量插入數(shù)據(jù)時該如何解決重復(fù)問題詳解
之前寫的代碼批量插入遇到了問題,原因是有重復(fù)的數(shù)據(jù)(主鍵或唯一索引沖突),所以插入失敗,下面這篇文章主要給大家介紹了關(guān)于Mysql批量插入數(shù)據(jù)時該如何解決重復(fù)問題的相關(guān)資料,需要的朋友可以參考下2022-11-11