亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > MySQL > 正文

MySQL InnoDB 二級索引的排序示例詳解

2024-07-25 19:09:29
字體:
來源:轉載
供稿:網友

排序問題

最近看了極客時間上 《MySQL實戰45講》,糾正了一直以來對 InnoDB 二級索引的一個理解不到位,正好把相關內容總結下。

PS:本文的所有測試基于 MySQL 8.0.13 。

先把問題拋出來,下面的 SQL 所創建的表,有兩個查詢語句,哪個索引是非必須的?

CREATE TABLE `geek` ( `a` int(11) NOT NULL, `b` int(11) NOT NULL, `c` int(11) NOT NULL, `d` int(11) NOT NULL, PRIMARY KEY (`a`,`b`), KEY `c` (`c`), KEY `ca` (`c`,`a`), KEY `cb` (`c`,`b`)) ENGINE=InnoDB;select * from geek where c=N order by a limit 1;select * from geek where c=N order by b limit 1;

作者給的答案是索引 c 和 ca 的數據模型是一樣的,因此 ca 是多余的。為啥??

我們知道,二級索引里存放的不是行的位置,而是主鍵的值,也知道索引是有序的。

如果 c 與 ca 的數據模型一樣,那么就要求二級索引的葉子節點不僅是按索引列排序、而且還按關聯的主鍵值進行排序。

我以前的理解是 二級索引只按索引列進行排序,主鍵值是不排序的。

問了專欄作者,得到的答復是:索引 c 就是按照 cab 這樣排序,(二級索引))有保證主鍵算進去、還是有序的。(PS:非原話,前后問了三次得到)。

本著 先問是不是,再問為什么 的思路,進行一番探究。

是不是?

如果能直接看 InnoDB 的數據文件,那就可以直接看出是不是遵循了這樣的排序規則??上鞘嵌M制文件,又沒有順手的工具可以方便查看,放棄。

后來找到了 MySQL 的 handler 語句,它支持 MyISAM/InnoDB 兩種引擎的表。handler 語句提供了直接訪問表存儲引擎的接口。

下面的語法表示讀取指定表指定索引的 第一條/前一條/下一條/最后一條 記錄。

handler table_name/table_name_alias read index_name first/pre/next/last;

就用 handler 語句來驗證下,先建一個簡單的表,插入幾條數據:

create table t_simple ( id int primary key, v int, key k_v (v)) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;insert into t_simple values (1, 5);insert into t_simple values (10, 5);insert into t_simple values (4, 5);

上面的插入語句,二級索引列的值都是一樣的,主鍵不是按順序的,這樣就可以看遍歷時是不是按主鍵順序存放的。

mysql> handler t_simple open as ts;Query OK, 0 rows affected (0.00 sec)mysql> handler ts read k_v next;+----+------+| id | v |+----+------+| 1 | 5 |+----+------+1 row in set (0.00 sec)mysql> handler ts read k_v next;+----+------+| id | v |+----+------+| 4 | 5 |+----+------+1 row in set (0.00 sec)mysql> handler ts read k_v next;+----+------+| id | v |+----+------+| 10 | 5 |+----+------+1 row in set (0.00 sec)

從結果可以看到,遍歷的二級索引,值相等時,按主鍵的順序遍歷,基本可以確定二級索引不僅按索引列排序,還按主鍵值排序了。

為什么?

之前一直沒看到說 MySQL 有這樣的機制,問了前公司和先公司的 DBA 都沒了解過這個。

最后 DBA 同事找到了 索引擴展, Index Extensions ,里面有這么段描述做了說明:

InnoDB automatically extends each secondary index by appending the primary key columns to it. Consider this table definition:

CREATE TABLE t1 ( i1 INT NOT NULL DEFAULT 0, i2 INT NOT NULL DEFAULT 0, d DATE DEFAULT NULL, PRIMARY KEY (i1, i2), INDEX k_d (d)) ENGINE = InnoDB;

InnoDB 自動擴展每個二級索引,把主鍵值追加到索引列后面,把擴展后的組合列作為該索引的索引列。對于上面 t_simple 表的 k_v 索引,擴展后是 (v, id)列。

優化器會根據擴展后的二級索引的主鍵列來決定如何和是否使用那個索引。優化器可以用擴展的二級索引來進行 ref,range,index_merge 等類型的索引訪問、松散的索引掃描、連接和排序優化,以及 min()/max() 優化。

可以用 show variables like '%optimizer_switch%'; 查看索引擴展是否開啟;用 SET optimizer_switch = 'use_index_extensions=on/off'; 進行開啟或關閉,這個只影響當前會話。

經測試,哪怕關閉了當前會話的索引擴展,用 handler 訪問時仍然有按主鍵排序的效果。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對VeVb武林網的支持。


注:相關教程知識閱讀請移步到MYSQL教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
中文字幕av一区二区| 亚洲黄色在线观看| 亚洲欧美999| 黄色成人在线播放| 亚洲综合大片69999| 日韩成人激情在线| 欧美激情视频给我| 97在线视频免费播放| 国产成人97精品免费看片| 亚洲色图在线观看| 久久91精品国产91久久跳| 欧美成人激情图片网| 国产午夜精品理论片a级探花| 国产精品都在这里| 欧美韩国理论所午夜片917电影| 日韩欧美国产视频| 久久久久久这里只有精品| 日韩最新中文字幕电影免费看| 久久影视电视剧免费网站清宫辞电视| 欧美噜噜久久久xxx| 最近2019年日本中文免费字幕| 日韩欧美亚洲一二三区| 欧美精品久久久久久久久| 久久久久久久国产精品| 国产精品午夜一区二区欲梦| 久久久国产精品免费| 性欧美长视频免费观看不卡| 亲爱的老师9免费观看全集电视剧| 国产一区二区三区久久精品| …久久精品99久久香蕉国产| 久久成人18免费网站| 欧美一区二粉嫩精品国产一线天| 亚洲高清在线观看| 欧美日韩在线第一页| 国产在线拍偷自揄拍精品| 中文欧美日本在线资源| 亚洲精品白浆高清久久久久久| 亚洲国产一区自拍| 久久久这里只有精品视频| 欧美日韩爱爱视频| 亚洲天堂男人天堂女人天堂| 亚洲精品资源在线| 国产日韩欧美自拍| 久久久精品久久久久| 久久九九全国免费精品观看| 欧美黑人一级爽快片淫片高清| 欧美成人一区在线| 国产精品午夜国产小视频| 久久久久久国产三级电影| 久久久精品国产网站| 日韩av第一页| 黑人狂躁日本妞一区二区三区| 九九热精品视频国产| 亚洲第一综合天堂另类专| 国产视频999| 亚洲色图校园春色| 日韩av在线播放资源| 一区二区三区视频免费在线观看| 亚洲 日韩 国产第一| 国产一区二中文字幕在线看| 欧美日韩视频在线| 九九热精品在线| 国产69精品99久久久久久宅男| www.欧美视频| 亚洲国产第一页| 国产精品一区久久久| 久久精品影视伊人网| 日韩欧美亚洲范冰冰与中字| 亚洲一区二区三区乱码aⅴ蜜桃女| 久久久久久久999精品视频| 亚洲精品ady| 上原亚衣av一区二区三区| 精品亚洲一区二区三区| 亚洲毛茸茸少妇高潮呻吟| 欧美日韩国产中文字幕| 丝袜美腿精品国产二区| 欧美大片在线看免费观看| 日韩欧美一区二区在线| 欧美国产极速在线| 91社影院在线观看| 欧美日韩中文字幕| 日韩中文字幕网站| 亚洲欧洲在线播放| 伊人青青综合网站| 日韩精品免费观看| 精品国产拍在线观看| 国产91色在线播放| 久久久久久尹人网香蕉| 精品一区二区亚洲| 亚洲人成电影网| 日韩欧美精品在线观看| www.久久撸.com| 久久综合伊人77777| 久久国内精品一国内精品| 亚洲欧美日韩一区二区三区在线| 狠狠久久五月精品中文字幕| 国产日韩欧美日韩大片| 亚洲女人初尝黑人巨大| 亚洲久久久久久久久久久| 91夜夜未满十八勿入爽爽影院| 中文字幕精品一区二区精品| 91精品国产综合久久久久久久久| 久久亚洲私人国产精品va| 久久久久久久久91| 中文字幕v亚洲ⅴv天堂| 国产综合视频在线观看| 久久亚洲国产精品成人av秋霞| 欧美日韩国产一区中文午夜| 久久久噜噜噜久噜久久| 日韩免费精品视频| 在线观看欧美日韩国产| 国产成人精品在线视频| 久久亚洲电影天堂| 欧美老少配视频| 九九精品在线观看| 日韩不卡中文字幕| 日本亚洲欧洲色| 欧美日韩国产成人| 亚洲自拍高清视频网站| 欧美激情免费观看| 国产69精品久久久久久| 色狠狠av一区二区三区香蕉蜜桃| 日韩免费观看在线观看| 久久久成人精品| 色yeye香蕉凹凸一区二区av| 欧美乱妇高清无乱码| 国产免费一区二区三区在线能观看| 亚洲欧美成人一区二区在线电影| 日韩风俗一区 二区| 久久成人18免费网站| 国产成人激情视频| 国产精品久久久久久久天堂| 日韩av中文字幕在线免费观看| 在线观看精品自拍私拍| 国产香蕉97碰碰久久人人| 国产欧美精品日韩精品| 亚洲黄页网在线观看| 国内精品久久久久| 日韩av在线网页| 91精品久久久久久久久青青| 久久久久久久久91| 欧美色xxxx| 欧美老女人在线视频| 日韩禁在线播放| 国产精品91久久久久久| 6080yy精品一区二区三区| 中文字幕精品一区二区精品| 中文字幕v亚洲ⅴv天堂| 亚洲国产一区二区三区四区| 成人高h视频在线| 日本欧美国产在线| 国产欧美韩国高清| 欧美激情欧美狂野欧美精品| 26uuu久久噜噜噜噜| 亚洲女性裸体视频| 国产日韩在线亚洲字幕中文| 亚洲欧美日韩网| 欲色天天网综合久久| 日韩av中文字幕在线| 全球成人中文在线| 欧美久久精品午夜青青大伊人| 91精品国产自产在线观看永久| 国产一区二区在线免费视频| 亚洲人成绝费网站色www|