前言:前面已經學習了explain(執行計劃)的相關知識,這裏利用explain對索引進行優化分析。html
首先建立三張表:tb_emp(職工表)、tb_dept(部門表)和tb_desc(描述表)緩存
1)tb_emp表。學習
DROP TABLE IF EXISTS `tb_emp`; CREATE TABLE `tb_emp` ( `id` int(11) NOT NULL AUTO_INCREMENT, `username` varchar(20) NOT NULL,
`deptid` int(11) NOT NULL,
PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4; -- ---------------------------- INSERT INTO `tb_emp`(username,deptid) VALUES ('Tom', '1'); INSERT INTO `tb_emp`(username,deptid) VALUES ('Jack', '1'); INSERT INTO `tb_emp`(username,deptid) VALUES ('Mary', '2'); INSERT INTO `tb_emp`(username,deptid) VALUES ('Rose', '3');
2)tb_dept表。測試
DROP TABLE IF EXISTS `tb_dept`; CREATE TABLE `tb_dept` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(20) NOT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4; -- ---------------------------- INSERT INTO `tb_dept`(name) VALUES ('綜合部'); INSERT INTO `tb_dept`(name) VALUES ('研發'); INSERT INTO `tb_dept`(name) VALUES ('測試'); INSERT INTO `tb_dept`(name) VALUES ('總裁');
3)tb_desc表。優化
DROP TABLE IF EXISTS `tb_desc`; CREATE TABLE `tb_desc` ( `id` int(11) NOT NULL AUTO_INCREMENT, `empid` int(11) DEFAULT NULL, `deptid` int(11) DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4; -- ---------------------------- INSERT INTO `tb_desc`(empid,deptid) VALUES (1, 1); INSERT INTO `tb_desc`(empid,deptid) VALUES (2, 1); INSERT INTO `tb_desc`(empid,deptid) VALUES (3, 2); INSERT INTO `tb_desc`(empid,deptid) VALUES (4, 3);
注:這裏強行將員工表與部門表不直接關聯,經過第三張表(描述表)進行關聯,主要爲了進行join的分析。spa
#1.首先執行查詢。code
#2.經過explain進行分析。htm
分析:從explain執行結果能夠看出對兩表都是用了全表掃描(ALL),而且在tb_desc表中還使用了join鏈接緩存,須要進行優化。可是如何優化?是在左表創建索引仍是右表創建索引呢?由於左鏈接左表是全有,因此應該在右表創建索引。blog
#3.右表建立索引。索引
經過explain執行能夠看到,在建立索引後,得到了比較不錯的結果。(type=ref,Extra=Using index)。
結論:left join(左鏈接)狀況下,應該在右表(tb_desc)建立索引。
經過上面left join的例子,咱們直接交換兩表位置,並將left join改變成right join。
分析:
與left join進行對比,能夠獲得以下結論:
#1.在left join下,首先執行tb_emp(左表),type=ALL,由於左鏈接狀況下左表全有,所以咱們在tb_desc(右表)建立索引,獲得比較理想的效果。
#2.在right join下(咱們交換了tb_emp和tb_desc的位置),執行順序:tb_emp(右表)→ tb_desc(左表)。右表type=ALL,由於右鏈接狀況下右表全有,所以在左表(tb_desc,咱們交換了位置)建立索引,效果確定和left join同樣。
left join(左鏈接):右表建立索引。
right join(右鏈接):左表建立索引。
簡記:左右外鏈接,索引相反建(left:右表建,right:左表建)。
by Shawn Chen,2018.6.23日,晚。