失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > mysql聚簇索引 和主键的区别_[MySQL] innoDB引擎的主键与聚簇索引

mysql聚簇索引 和主键的区别_[MySQL] innoDB引擎的主键与聚簇索引

时间:2021-01-17 00:06:57

相关推荐

mysql聚簇索引 和主键的区别_[MySQL] innoDB引擎的主键与聚簇索引

MysqL的innodb引擎本身存储的形式就必须是聚簇索引的形式,在磁盘上树状存储的,但是不一定是根据主键聚簇的,有三种情形:

1. 有主键的情况下,主键就是聚簇索引

2. 没有主键的情况下,第一个非空null的唯一索引就是聚簇索引

3. 如果上面都没有,那么就是有一个隐藏的row-id作为聚簇索引

大部分情况下,我们建表的时候都会创建主键,因此大部分都是根据主键聚簇的

当我们根据主键字段来进行查询时,效率是最高的,不需要二次查找,直接主键字段查询索引树,叶子节点就是存储的数据了

当我们根据主键查询时,如果就只有唯一一条,那么执行计划是下面这样的,差不多是最高效的 . type是const row只需要扫描一行

+----+-------------+-------+-------+---------------+---------+---------+-------+------+-------+

| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |

+----+-------------+-------+-------+---------------+---------+---------+-------+------+-------+

| 1 | SIMPLE | tblz | const | PRIMARY | PRIMARY | 4 | const | 1 | |

+----+-------------+-------+-------+---------------+---------+---------+-------+------+-------+

总结

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。

如您喜欢交流学习经验,点击链接加入交流1群:1065694478(已满)交流2群:163560250

如果觉得《mysql聚簇索引 和主键的区别_[MySQL] innoDB引擎的主键与聚簇索引》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。