MySQL中myisam和innodb的主键索引有什么区别

2024-12-19 06:09:28
推荐回答(2个)
回答1:

mysql中的索引是在存储引擎中实现的 ,mysql有很多存储引擎 但是大部分都采用B+tree作为索引结构的 其中包括myisam和innodb。
myisam索引文件和数据文件是分离的,myisam索引的存储方式是非聚合的,索引文件存储在MYI文件。
innodb 索引和数据文件是保存在一起的;数据共享的话会放在ibdata,独享的话会放在ibd
innodb每个表只有一个聚集索引。如果木有主键,则会选择一个非空唯一索引来代替主键;如果再不存在则会定义一个隐藏的主键进行聚集。
所谓聚集和非聚集:
非聚集索引叶子页包含一个指向表中的记录的指针地址,记录的物理顺序和索引的顺序不一致;
聚集索引则数据行和键值一起保存在叶子页 而且记录的排列顺序与索引的排列顺序一致。

回答2:

InnoDB 被称为索引组织型的存储引擎。主键使用的 B-Tree 来存储数据,即表行。这意味着 InnoDB 必须使用主键。如果表没有主键,InnoDB 会向表中添加一个隐藏的自动递增的 6 字节计数器,并使用该隐藏计数器作为主键。InnoDB 的隐藏主键存在一些问题。您应该始终在表上定义显式主键,并通过主键值访问所有 InnoDB 行。InnoDB 的二级索引也是一个B-Tree。搜索关键字由索引列组成,存储的值是匹配行的主键。通过二级索引进行搜索通常会导致主键的隐式搜索。