欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL組合索引與最左匹配原則詳解

 更新時間:2019年03月16日 11:17:35   作者:Wolf、Heart  
這篇文章主要給大家介紹了關(guān)于MySQL組合索引與最左匹配原則的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用Mysql具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧

前言

之前在網(wǎng)上看到過很多關(guān)于mysql聯(lián)合索引最左前綴匹配的文章,自以為就了解了其原理,最近面試時和面試官交流,發(fā)現(xiàn)遺漏了些東西,這里自己整理一下這方面的內(nèi)容。

什么時候創(chuàng)建組合索引?

當(dāng)我們的where查詢存在多個條件查詢的時候,我們需要對查詢的列創(chuàng)建組合索引

為什么不對沒一列創(chuàng)建索引

  • 減少開銷
  • 覆蓋索引
  • 效率高

減少開銷:假如對col1、col2、col3創(chuàng)建組合索引,相當(dāng)于創(chuàng)建了(col1)、(col1,col2)、(col1,col2,col3)3個索引
覆蓋索引:假如查詢SELECT col1, col2, col3 FROM 表名,由于查詢的字段存在索引頁中,那么可以從索引中直接獲取,而不需要回表查詢

效率高:對col1、col2、col3三列分別創(chuàng)建索引,MySQL只會選擇辨識度高的一列作為索引。假設(shè)有100w的數(shù)據(jù),一個索引篩選出10%的數(shù)據(jù),那么可以篩選出10w的數(shù)據(jù);對于組合索引而言,可以篩選出100w*10%*10%*10%=1000條數(shù)據(jù)

最左匹配原則

假設(shè)我們創(chuàng)建(col1,col2,col3)這樣的一個組合索引,那么相當(dāng)于對col1列進(jìn)行排序,也就是我們創(chuàng)建組合索引,以最左邊的為準(zhǔn),只要查詢條件中帶有最左邊的列,那么查詢就會使用到索引

創(chuàng)建測試表

CREATE TABLE `student` (
 `id` int(11) NOT NULL,
 `name` varchar(10) NOT NULL,
 `age` int(11) NOT NULL,
 PRIMARY KEY (`id`),
 KEY `idx_id_name_age` (`id`,`name`,`age`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8

填充100w測試數(shù)據(jù)

DROP PROCEDURE pro10;
CREATE PROCEDURE pro10()
BEGIN
	DECLARE i INT;
	DECLARE char_str varchar(100) DEFAULT 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789';
	DECLARE return_str varchar(255) DEFAULT '';
	DECLARE age INT;
	SET i = 1;
	WHILE i < 5000000 do
		SET return_str = substring(char_str, FLOOR(1 + RAND()*62), 8);
		SET i = i+1;
		SET age = FLOOR(RAND() * 100);
		INSERT INTO student(id, name, age) values(i, return_str, age);
	END WHILE;
END;

CALL pro10();

場景測試

EXPLAIN SELECT * FROM student WHERE id = 2;

可以看到該查詢使用到了索引

EXPLAIN SELECT * FROM student WHERE id = 2 AND name = 'defghijk';

可以看到該查詢使用到了索引

EXPLAIN SELECT * FROM student WHERE id = 2 AND name = 'defghijk' and age = 8;

可以看到該查詢使用到了索引

EXPLAIN SELECT * FROM student WHERE id = 2 AND age = 8;

可以看到該查詢使用到了索引

EXPLAIN SELECT * FROM student WHERE name = 'defghijk' AND age = 8;

可以看到該查詢沒有使用到索引,類型為index,查詢行數(shù)為4989449,幾乎進(jìn)行了全表掃描,由于組合索引只針對最左邊的列進(jìn)行了排序,對于name、age只能進(jìn)行全部掃描

EXPLAIN SELECT * FROM student WHERE name = 'defghijk' AND id = 2;

EXPLAIN SELECT * FROM student WHERE age = 8 AND id = 2;

EXPLAIN SELECT * FROM student WHERE name = 'defghijk' and age = 8 AND id = 2;

可以看到如上查詢也使用到了索引,id放前面和放后面查詢到的結(jié)果是一樣的,MySQL會找出執(zhí)行效率最高的一種查詢方式,就是先根據(jù)id進(jìn)行查詢

總結(jié)

如上測試,可以看到只要查詢條件的列中包含組合索引最左邊的那一列,不管該列在查詢條件中的位置,都會使用索引進(jìn)行查詢。

好了,以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對腳本之家的支持。

相關(guān)文章

  • Mysql如何查詢字符串開頭的數(shù)據(jù)

    Mysql如何查詢字符串開頭的數(shù)據(jù)

    這篇文章主要介紹了Mysql如何查詢字符串開頭的數(shù)據(jù)問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-07-07
  • MySql增量恢復(fù)的幾種實現(xiàn)方法

    MySql增量恢復(fù)的幾種實現(xiàn)方法

    本文主要介紹了MySql增量恢復(fù)的幾種實現(xiàn)方法,通過增量備份與恢復(fù),可以在系統(tǒng)發(fā)生故障或數(shù)據(jù)損壞時快速恢復(fù)到最新狀態(tài),提高系統(tǒng)的可靠性和可用性,感興趣的可以了解一下
    2023-08-08
  • Mysql的MERGE存儲引擎詳解

    Mysql的MERGE存儲引擎詳解

    在本文里我們給大家整理了關(guān)于Mysql的MERGE存儲引擎的相關(guān)知識點內(nèi)容,有需要的讀者們學(xué)習(xí)下。
    2019-02-02
  • mysql中insert語句的5種用法簡單示例

    mysql中insert語句的5種用法簡單示例

    這篇文章主要給大家介紹了關(guān)于mysql中insert語句的5種用法的相關(guān)資料,insert into是mysql中最常用的插入語句,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-08-08
  • 允許遠(yuǎn)程用戶訪問mysql服務(wù)sql語句

    允許遠(yuǎn)程用戶訪問mysql服務(wù)sql語句

    本節(jié)主要介紹了如何允許遠(yuǎn)程用戶訪問mysql服務(wù),本例授權(quán)192.168.14.1 主機(jī)的cakephp用戶訪問cakephp數(shù)據(jù)庫
    2014-07-07
  • MySQL之表碎片化的問題解決

    MySQL之表碎片化的問題解決

    MySQL數(shù)據(jù)庫的碎片是由于頻繁的增刪改查操作導(dǎo)致的數(shù)據(jù)塊不連續(xù)或不規(guī)則分布,本文主要介紹了MySQL之表碎片化的問題解決,具有一定的參考價值,感興趣的可以了解一下
    2024-08-08
  • MySQL8.x使用GRANT為用戶賦權(quán)時報錯的解決

    MySQL8.x使用GRANT為用戶賦權(quán)時報錯的解決

    這篇文章主要介紹了MySQL8.x使用GRANT為用戶賦權(quán)時報錯的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • MySQL5.6安裝步驟圖文詳解

    MySQL5.6安裝步驟圖文詳解

    這篇文章主要為大家詳細(xì)介紹了MySQL安裝步驟配置方法圖文,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-10-10
  • my.cnf(my.ini)重要參數(shù)優(yōu)化配置說明

    my.cnf(my.ini)重要參數(shù)優(yōu)化配置說明

    本文針對mysql不同存儲引擎,MyISAM與Innodb進(jìn)行了講解如何進(jìn)行my.cnf(my.ini)的參數(shù)優(yōu)化
    2018-03-03
  • 連接mysql的常用工具分享

    連接mysql的常用工具分享

    這篇文章主要介紹了連接mysql的常用工具,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-02-02

最新評論