拜访办法的概念
设计 MySQL 的大叔把 MySQL 执行查问语句的形式称为拜访办法(access method)或者拜访类型。同一个查问语句能够应用多种不同的拜访办法来执行,尽管最初的查问后果都是一样的,然而不同的执行形式话费的工夫老本可能差距甚大。就像是从北京南锣鼓巷到什刹海,你能够打车去,也能够坐地铁去,坐公交去,还能够骑共享单车去,当然也能够走着去。
表构造
CREATE TABLE single_table(
id int not null auto_increment,
key1 VARCHAR(100),
key2 int,
key3 VARCHAR(100),
key_part1 VARCHAR(100),
key_part2 VARCHAR(100),
key_part3 VARCHAR(100),
common_field VARCHAR(100),
PRIMARY KEY(id),
key idx_key1(key1),
unique key uk_key2(key2),
key idx_key3(key3),
key idx_key_part(key_part1,key_part2,key_part3)
)engine=INNODB charset=utf8mb4
const
有时须要通过主键列定位一条记录,如下:
select * from single_table where id = 12;
MySQL 会间接利用主键值在聚簇索引中定位对应的用户记录,如下:
与之相似,咱们依据惟一二级索引列来定位一条记录的速度也是贼快的。比方上面的查问:
select * from single_talbe where key2 = 12;
这个查问的执行过程的示意图如下:
能够看到这个查问的执行分为上面两步:
- 步骤 1. 在 uk_key2 对应的 B + 树索引中,依据 key2 列与常数的等值比拟条件定位到一条二级索引记录。
- 步骤 2. 而后再依据该记录的 id 值到聚簇索引中获取到残缺的用户记录。
设计 MySQL 的大叔认为,通过主键或者惟一二级索引列与常数的等值比拟来定位一条记录像是坐火箭一样快的,所以他们把这种通过主键或者惟一二级索引列来定位一条记录的拜访办法定义为 const(意思是常数级别的,代价是能够忽略不计的)。不过这种 const 拜访办法只能在主键列或者惟一二级索引列与一个常数进行等值比拟时才无效。如果主键或者惟一二级索引的索引列由多个列形成,则只有在索引列中的每一个列都与常数进行等值比拟时,这个 const 拜访办法才无效(这是因为只有在该索引的每一个列都采纳等值比拟时,才能够保障最多只有一条记录合乎搜寻条件)。
对于惟一二级索引来说,在查问列为 null 值时,状况比拟非凡。比方上面这样:
select * from single_table where key2 is null;
因为惟一二级索引列并不限度 null 值的数量,所以上述语句可能拜访到多条记录。也就是说下面这个语句不能够应用 const 拜访办法来执行。