IT技术博客大学习 共学习 共进步
全部 移动开发 后端 数据库 AI 算法 安全 DevOps 前端 设计 开发者

InnoDB主键设计

MySQL 中文网 - 2010-08-03 23:54:23 累计浏览 3,465 次
本机暂存
众所周知,InnoDB是clustered-index table,因此对于InnoDB而言,主键具有特殊意义。可以通过主键直接定位到对应的某一数据行记录的物理位置,主键索引指向对应行记录,其他索引则都指向主键索引;因此,可以这么说,InnoDB其实就是一个 B-树索引,这棵B-树的索引就是主键,它的值则是对应的行记录。
在InnoDB数据表设计中,我们需要注意几点:
  • 1. 显式的定义一个 INT 类型自增字段的主键,这个字段可以仅用于做主键,不做其他用途
  • 2. 如果不显式定义主键的话,可能会导致InnoDB每次都需要对新数据行进行排序,严重损害性能
  • 3. 尽量保证不对主键字段进行更新修改,防止主键字段发生变化,引发数据存储碎片,降低IO性能
  • 4. 如果需要对主键字段进行更新,请将该字段转变成一个唯一索引约束字段,另外创建一个没有其他业务意义的自增字段做主键
  • 5. 主键字段类型尽可能小,能用SMALLINT就不用INT,能用INT就不用BIGINT
  • 6. 主键字段放在数据表的第一顺序

同分类推荐文章

  1. 使用deepseek进行Oracle恢复,引起重大故障 (2026-06-22 10:56:00)
  2. 接手一个只差临门一脚的数据库恢复 (2026-06-18 00:13:09)
  3. 我做了一个 AI 版的 StarRocks 升级风险扫描工具,直接帮我定位到一个风险 (2026-06-15 01:00:00)

查看更多 数据库 文章 →

建议继续学习

  1. 深入浅出INNODB MVCC机制与原理 (累计阅读 9,692)
  2. Innodb IO优化-配置优化 (累计阅读 7,723)
  3. Innodb分表太多或者表分区太多,会导致内存耗尽而宕机 (累计阅读 7,716)
  4. 由浅入深理解索引的实现(2) (累计阅读 7,705)
  5. MySQL中like语句及相关优化器tips (累计阅读 6,278)
  6. Innodb 表和索引结构 (累计阅读 6,221)
  7. InnODB和MyISAM索引统计集合 (累计阅读 6,231)
  8. 从load data引发的死锁说起 (累计阅读 6,140)
  9. 一次神奇的MySQL优化 (累计阅读 6,080)
  10. InnoDB线程并发检查机制 (累计阅读 5,793)