- 为什么非主键索引的叶子节点存放的数据是主键值而不是整条数据
数据冗余。如果存在多个非主键索引,每个索引的叶子节点都存储整条数据,会占用过多空间。虽然查询性能会有所提升。
便于维护。修改数据只需更新逐渐索引中主键id对应的内容即可。 - 为什么InnoDB表必须创建主键
如果用户使用InnoDB存储引擎建立表的时候,没有指定主键,则Mysql会自动找到一个合适的唯一索引作为主键,若找不到符合条件唯一索引条件的字段时,会生成类似于ROW_ID的虚拟列充当该InnoDB表的主键 - 为什么使用主键时推荐使用整型的自增主键
整型:索引树的建立需要通过比较结点的值的大小,相较于其他类型数据,整型数值可以更快的进行编码并且比较
自增:新的数据加入现有的索引树后,索引树只需依照固定的方向自旋即可,否则需要更多自旋次数
InnoDB索引
最新推荐文章于 2023-03-16 16:05:18 发布