时间:2023-10-29来源:系统城装机大师作者:佚名
设计MySQL的大叔把MySQL执行查询语句的方式称为访问方法(access method)或者访问类型。同一个查询语句可以使用多种不同的访问方法来执行,虽然最后的查询结果都是一样的,但是不同的执行方式话费的时间成本可能差距甚大。就像是从北京南锣鼓巷到什刹海,你可以打车去,也可以坐地铁去,坐公交去,还可以骑共享单车去,当然也可以走着去。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
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 |
有时需要通过主键列定位一条记录,如下:
1 | select * from single_table where id = 12; |
MySQL会直接利用主键值在聚簇索引中定位对应的用户记录,如下:
与之类似,我们根据唯一二级索引列来定位一条记录的速度也是贼快的。比如下面的查询:
1 | select * from single_talbe where key2 = 12; |
这个查询的执行过程的示意图如下:
可以看到这个查询的执行分为下面两步:
设计MySQL的大叔认为,通过主键或者唯一二级索引列与常数的等值比较来定位一条记录像是坐火箭一样快的,所以他们把这种通过主键或者唯一二级索引列来定位一条记录的访问方法定义为const(意思是常数级别的,代价是可以忽略不计的)。不过这种const访问方法只能在主键列或者唯一二级索引列与一个常数进行等值比较时才有效。如果主键或者唯一二级索引的索引列由多个列构成,则只有在索引列中的每一个列都与常数进行等值比较时,这个const访问方法才有效(这是因为只有在该索引的每一个列都采用等值比较时,才可以保证最多只有一条记录符合搜索条件)。
对于唯一二级索引来说,在查询列为null值时,情况比较特殊。比如下面这样:
1 | select * from single_table where key2 is null ; |
因为唯一二级索引列并不限制null值的数量,所以上述语句可能访问到多条记录。也就是说上面这个语句不可以使用const访问方法来执行。
2023-10-30
windows上的mysql服务突然消失提示10061 Unkonwn error问题及解决方案2023-10-30
MySQL非常重要的日志bin log详解2023-10-30
详解MySQL事务日志redo log一、单表查询 1、排序 2、聚合函数 3、分组 4、limit 二、SQL约束 1、主键约束 2、非空约束 3、唯一约束 4、外键约束 5、默认值 三、多表查询 1、内连接 1)隐式内连接: 2)显式内连接: 2、外连接 1)左外连接 2)右外连接 四...
2023-10-30
Mysql删除表重复数据 表里存在唯一主键 没有主键时删除重复数据 Mysql删除表中重复数据并保留一条 准备一张表 用的是mysql8 大家自行更改 创建表并添加四条相同的数据...
2023-10-30