004--Explain實戰詳解:id分析

1.id相同代表:執行順序由上到下

mysql> EXPLAIN SELECT t1.id from t1,t3,t2  where t1.id = t3.id and t3.id = t2.id and t2.id = 1;
+----+-------------+-------+------+---------------+------+---------+------+------+--------------------------------+
| id | select_type | table | type | possible_keys | key  | key_len | ref  | rows | Extra                          |
+----+-------------+-------+------+---------------+------+---------+------+------+--------------------------------+
|  1 | SIMPLE      | t1    | ALL  | NULL          | NULL | NULL    | NULL |    3 | Using where                    |
|  1 | SIMPLE      | t3    | ALL  | NULL          | NULL | NULL    | NULL |    3 | Using where; Using join buffer |
|  1 | SIMPLE      | t2    | ALL  | NULL          | NULL | NULL    | NULL |    3 | Using where; Using join buffer |
+----+-------------+-------+------+---------------+------+---------+------+------+--------------------------------+
mysql> EXPLAIN SELECT t1.id from t1,t2,t3  where t1.id = t3.id and t3.id = t2.id and t2.id = 1;
+----+-------------+-------+------+---------------+------+---------+------+------+--------------------------------+
| id | select_type | table | type | possible_keys | key  | key_len | ref  | rows | Extra                          |
+----+-------------+-------+------+---------------+------+---------+------+------+--------------------------------+
|  1 | SIMPLE      | t1    | ALL  | NULL          | NULL | NULL    | NULL |    3 | Using where                    |
|  1 | SIMPLE      | t2    | ALL  | NULL          | NULL | NULL    | NULL |    3 | Using where; Using join buffer |
|  1 | SIMPLE      | t3    | ALL  | NULL          | NULL | NULL    | NULL |    3 | Using where; Using join buffer |
+----+-------------+-------+------+---------------+------+---------+------+------+--------------------------------+
mysql> EXPLAIN SELECT * from t1,t2,t3 where t1.id = t2.id;
+----+-------------+-------+--------+---------------+---------+---------+--------------+------+-------------------+
| id | select_type | table | type   | possible_keys | key     | key_len | ref          | rows | Extra             |
+----+-------------+-------+--------+---------------+---------+---------+--------------+------+-------------------+
|  1 | SIMPLE      | t2    | ALL    | PRIMARY       | NULL    | NULL    | NULL         |    1 |                   |
|  1 | SIMPLE      | t1    | eq_ref | PRIMARY       | PRIMARY | 4       | mysql1.t2.id |    1 |                   |
|  1 | SIMPLE      | t3    | ALL    | NULL          | NULL    | NULL    | NULL         |    3 | Using join buffer |
+----+-------------+-------+--------+---------------+---------+---------+--------------+------+-------------------+
mysql> EXPLAIN SELECT * from t1,t2 where t1.id = t2.id;
+----+-------------+-------+--------+---------------+---------+---------+--------------+------+-------+
| id | select_type | table | type   | possible_keys | key     | key_len | ref          | rows | Extra |
+----+-------------+-------+--------+---------------+---------+---------+--------------+------+-------+
|  1 | SIMPLE      | t2    | ALL    | PRIMARY       | NULL    | NULL    | NULL         |    1 |       |
|  1 | SIMPLE      | t1    | eq_ref | PRIMARY       | PRIMARY | 4       | mysql1.t2.id |    1 |       |
+----+-------------+-------+--------+---------------+---------+---------+--------------+------+-------+
mysql> EXPLAIN SELECT * from t1,t2 where t2.id = t1.id;
+----+-------------+-------+--------+---------------+---------+---------+--------------+------+-------+
| id | select_type | table | type   | possible_keys | key     | key_len | ref          | rows | Extra |
+----+-------------+-------+--------+---------------+---------+---------+--------------+------+-------+
|  1 | SIMPLE      | t2    | ALL    | PRIMARY       | NULL    | NULL    | NULL         |    1 |       |
|  1 | SIMPLE      | t1    | eq_ref | PRIMARY       | PRIMARY | 4       | mysql1.t2.id |    1 |       |
+----+-------------+-------+--------+---------------+---------+---------+--------------+------+-------+

2.id不同代表:如果是子查詢,id越大的越先被執行,理解轉化為數學運算:1+(1*(1+1))

mysql> EXPLAIN SELECT t2.`name` from t2 where t2.id =(SELECT t1.id from t1 where t1.`name`= 'downeyjr_1');
+----+-------------+-------+------+---------------+------+---------+------+------+-------------+
| id | select_type | table | type | possible_keys | key  | key_len | ref  | rows | Extra       |
+----+-------------+-------+------+---------------+------+---------+------+------+-------------+
|  1 | PRIMARY     | t2    | ALL  | NULL          | NULL | NULL    | NULL |    3 | Using where |
|  2 | SUBQUERY    | t1    | ALL  | NULL          | NULL | NULL    | NULL |    3 | Using where |
+----+-------------+-------+------+---------------+------+---------+------+------+-------------+
mysql> EXPLAIN SELECT t2.`name` from t2 where t2.id =(SELECT t1.id from t1 where t1.`name`= (SELECT t3.`name` from t3 where t3.id= 2));
+----+-------------+-------+------+---------------+------+---------+------+------+-------------+
| id | select_type | table | type | possible_keys | key  | key_len | ref  | rows | Extra       |
+----+-------------+-------+------+---------------+------+---------+------+------+-------------+
|  1 | PRIMARY     | t2    | ALL  | NULL          | NULL | NULL    | NULL |    3 | Using where |
|  2 | SUBQUERY    | t1    | ALL  | NULL          | NULL | NULL    | NULL |    3 | Using where |
|  3 | SUBQUERY    | t3    | ALL  | NULL          | NULL | NULL    | NULL |    3 | Using where |
+----+-------------+-------+------+---------------+------+---------+------+------+-------------+

3.id相同又不同代表:先執行id值大的,然后順序執行id相同的

mysql> EXPLAIN SELECT t2.`name` from t2 ,(SELECT t3.* from t3 where t3.id= 2) t4 where t4.id = t2.id;
+----+-------------+------------+--------+---------------+------+---------+------+------+-------------+
| id | select_type | table      | type   | possible_keys | key  | key_len | ref  | rows | Extra       |
+----+-------------+------------+--------+---------------+------+---------+------+------+-------------+
|  1 | PRIMARY     | <derived2> | system | NULL          | NULL | NULL    | NULL |    1 |             |
|  1 | PRIMARY     | t2         | ALL    | NULL          | NULL | NULL    | NULL |    3 | Using where |
|  2 | DERIVED     | t3         | ALL    | NULL          | NULL | NULL    | NULL |    3 | Using where |
+----+-------------+------------+--------+---------------+------+---------+------+------+-------------+
mysql> EXPLAIN SELECT t4.`name` from (SELECT t3.* from t3 where t3.id= 2)t4,(SELECT t2.* from t2 where t2.id= 2)t5 where t4.id = t5.id ;
+----+-------------+------------+--------+---------------+------+---------+------+------+-------------+
| id | select_type | table      | type   | possible_keys | key  | key_len | ref  | rows | Extra       |
+----+-------------+------------+--------+---------------+------+---------+------+------+-------------+
|  1 | PRIMARY     | <derived2> | system | NULL          | NULL | NULL    | NULL |    1 |             |
|  1 | PRIMARY     | <derived3> | system | NULL          | NULL | NULL    | NULL |    1 |             |
|  3 | DERIVED     | t2         | ALL    | NULL          | NULL | NULL    | NULL |    3 | Using where |
|  2 | DERIVED     | t3         | ALL    | NULL          | NULL | NULL    | NULL |    3 | Using where |
+----+-------------+------------+--------+---------------+------+---------+------+------+-------------+

4.id使用總結:

  • id意義:MySQL Query Optimizer 選定的執行計劃中查詢的序列號。表示查詢中執行 select 子句或操作表的順序,id 值越大優先級越高,越先被執行。id 相同,執行順序由上至下。
  • id作用:表的讀取順序,小表驅動大表時的微調

5.執行的SQL文件

SET FOREIGN_KEY_CHECKS=0;

-- ----------------------------
-- Table structure for t1
-- ----------------------------
DROP TABLE IF EXISTS `t1`;
CREATE TABLE `t1` (
  `id` int(5) DEFAULT NULL,
  `name` varchar(10) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

-- ----------------------------
-- Records of t1
-- ----------------------------
INSERT INTO `t1` VALUES ('1', 'downeyjr_1');
INSERT INTO `t1` VALUES ('2', 'downeyjr_2');
INSERT INTO `t1` VALUES ('3', 'downeyjr_3');

-- ----------------------------
-- Table structure for t2
-- ----------------------------
DROP TABLE IF EXISTS `t2`;
CREATE TABLE `t2` (
  `id` int(5) DEFAULT NULL,
  `name` varchar(10) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

-- ----------------------------
-- Records of t2
-- ----------------------------
INSERT INTO `t2` VALUES ('1', 'downeyjr_1');
INSERT INTO `t2` VALUES ('2', 'downeyjr_2');
INSERT INTO `t2` VALUES ('3', 'downeyjr_3');

-- ----------------------------
-- Table structure for t3
-- ----------------------------
DROP TABLE IF EXISTS `t3`;
CREATE TABLE `t3` (
  `id` int(5) DEFAULT NULL,
  `name` varchar(10) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

-- ----------------------------
-- Records of t3
-- ----------------------------
INSERT INTO `t3` VALUES ('1', 'downeyjr_1');
INSERT INTO `t3` VALUES ('2', 'downeyjr_2');
INSERT INTO `t3` VALUES ('3', 'downeyjr_3');
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容

  • Spring Cloud為開發人員提供了快速構建分布式系統中一些常見模式的工具(例如配置管理,服務發現,斷路器,智...
    卡卡羅2017閱讀 134,973評論 19 139
  • 1. Java基礎部分 基礎部分的順序:基本語法,類相關的語法,內部類的語法,繼承相關的語法,異常的語法,線程的語...
    子非魚_t_閱讀 31,767評論 18 399
  • CREATE TABLE IF NOT EXISTS ecs_order_info (order_id mediu...
    cookie口閱讀 15,762評論 0 16
  • 國家電網公司企業標準(Q/GDW)- 面向對象的用電信息數據交換協議 - 報批稿:20170802 前言: 排版 ...
    庭說閱讀 11,176評論 6 13
  • ceshiceshi
    黃浩霖閱讀 102評論 0 0