密集索引
密集索引文件中每一个搜索码值都对应一个索引值,就是叶子节点保存的不只是键值,还保存了位于同一行记录里的其他列的信息,由于密集索引决定了表的物理排列顺序,一个表只有一个物理排列顺序,所以一个表只能创建一个密集索引
稀疏索引
稀疏索引文件只为索引码的某些值建立索引项, 比如 InnoDB的其他索引只存了键位信息和主键, MyISAM的所有索引都是
InnoDB
如果一个主键被定义了,那么这个主键就是作为密集索引
如果主键没有被定义,那么该表中第一个唯一非空的索引则作为密集索引
如果不满足以上条件,InnoDB内部会生成隐藏主键作为密集索引
非主键索引存储相关键位何其对应的主键值,包含两次查找
MyISAM
不管是主键索引,唯一键索引,还是普通索引都是稀疏索引