主键
表中每一行都应该有可以唯一标识自己的一列(或一组列)。
一个顾客可以使用顾客编号列,而订单可以使用订单ID,雇员可以使用雇员ID 或 雇员社会保险号。
主键(primary key) 一列(或一组列),其值能够唯一区分表中的每个行。
唯一标识表中每行的这个列(或这组列)称为主键。没有主键,更新或删除表中特定行很困难,因为没有安全的方法保证只设计相关的行。
虽然并不总是都需要主键,但大多数数据库设计人员都应保证他们创建的每个表有一个主键,以便于以后数据操纵和管理
表中的任何列都可以作为主键,只要它满足一下条件:
1、任何两行都不具有相同的主键值
2、每个行都必须具有一个主键值(主键列不允许NULL值)
主键值规范:这里列出的规则是MySQL本身强制实施的。
主键的最好习惯:
除MySQL强制实施的规则外,应该坚持的几个普遍认为的最好习惯为:
1、不更新主键列的值
2、不重用主键列的值
3、不在主键列中使用可能会更改的值(例如,如果使用一个名字作为主键以标识某个供应商,应该供应商合并和更改其名字时,必须更改这个主键)
总之:不应该使用一个具有意义的column(id 本身并不保存表 有意义信息) 作为主键,并且一个表必须要有一个主键,为方便扩展、松耦合,高可用的系统做铺垫。
非常感谢 @pathbox、 @est、@hooooopo 同学的提醒。主键的作用,在于索引。
无特殊需求下Innodb建议使用与业务无关的自增ID作为主键
InnoDB引擎使用聚集索引