我們都知道在 MySql 中使用索引可以提高查詢效率,但有時候真正執行Sql查詢的時候卻沒有按照我們的預想使用索引,而是全表掃描,導致有慢Sql影響了整個網站的效率,甚至導致網站崩潰,所以我們需要了解Mysql是如何選擇使用索引的,以便建立合適的索引 (本文基於MySql5.7,InnoDB引擎)
前提:建立一張測試表
假設有一張使用者表
CREATE TABLE `test_user` (
`user_id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(20) NOT NULL DEFAULT '',
`birthday` date NOT NULL,
`sex` tinyint(1) DEFAULT NULL,
`height` int(11) NOT NULL,
`weight` int(11) NOT NULL,
PRIMARY KEY (`user_id`),
KEY `idx_name_height_weight` (`name`,`height`,`weight`),
KEY `idx_height` (`height`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
複製程式碼
我們建立了name,height,weight 的聯合索引,插入測試資料
INSERT INTO `test_user` (`user_id`, `name`, `birthday`, `sex`, `height`, `weight`)
VALUES
(1, 'Tony', '1991-01-01', 1, 176, 65),
(2, 'Mary', '1989-12-19', 2, 160, 50),
(3, 'Tom', '1996-05-29', 1, 180, 70),
(4, 'Kiven', '1994-08-09', 1, 190, 80),
(5, 'John', '1992-11-12', 1, 182, 75);
複製程式碼
執行什麼操作的時候Mysql會使用索引
查詢與WHERE子句匹配的行
select * from test_user where name='mary'
複製程式碼
檢視執行計劃
data:image/s3,"s3://crabby-images/25670/25670ee59cb8a6a015fe21a423c660c2f21b935c" alt="MySql如何使用索引(一)"
從表中刪除一行資料
DELETE from test_user where name='mary';
複製程式碼
檢視執行計劃
data:image/s3,"s3://crabby-images/cd76c/cd76c56fe9b98aeacc6a6a391abc7c466dc7230b" alt="MySql如何使用索引(一)"
查詢索引列的MIN()或MAX()的值
SELECT MIN(height) FROM `test_user`
複製程式碼
data:image/s3,"s3://crabby-images/59af8/59af8a6d0e62c99a9c0328a1d607894d97a0350b" alt="MySql如何使用索引(一)"
SELECT MIN(height) from `test_user` where height>=176 AND height<=190;
複製程式碼
data:image/s3,"s3://crabby-images/e9c4c/e9c4cd0258fedd64c0b10f069f32e717225437c4" alt="MySql如何使用索引(一)"
SELECT MIN(height) from test_user where sex=1;
複製程式碼
data:image/s3,"s3://crabby-images/a0da0/a0da0f218af4b9e317f83165b6b0b9173e7a6ee1" alt="MySql如何使用索引(一)"
在索引列上執行 SORT 或 ORDER BY 操作
SELECT name,height from test_user ORDER BY `name` DESC;
複製程式碼
data:image/s3,"s3://crabby-images/6b8fc/6b8fc621a307c672f74faf73e0d4ef63d121af48" alt="MySql如何使用索引(一)"
data:image/s3,"s3://crabby-images/cb972/cb972c37434962e40cdfe7aee95cf8dc38a57c0f" alt="MySql如何使用索引(一)"
本文講述了MySql什麼時候會使用索引,下章說明什麼時候MySql不能使用索引,敬請期待