4.1 索引组织表
1.在innodb存储引擎中,每张表都有个主键,如果在创建表时没有显式地定义主键,则innodb存储引擎会按如下方式选择或创建主键:
①:首先判断表中是否有非空的唯一索引,如果有,则该列即为主键
②:如果不符合上述条件,innodb会自动创建一个6字节大小的指针。
当表中有多个非空唯一索引时,innodb存储引擎将选择建表时第一个定义的非空唯一索引为主键。主键的选择根据的是定义索引的顺序,而不是建表时列的顺序。
如果启用了innodb_file_per_table参数,需要注意的是每张表的表空间内存放的只是数据,索引和插入缓冲bitmap页,其他类的数据,如回滚(undo)信息,插入缓冲索引页,系统事务信息,二次写缓冲(double write)等还是存放在原来的共享表空间内。