P131)创建表时的默认引擎是InnoDB,如果要修改默认的存储引擎,可以在参数文件中设置default-table-type。查看当前的默认存储引擎,可以使用一下命令:
创建新表的时候可以通过增加ENGINE关键字设置新建表的存储引擎。也可以通过ALTER TABLE语句,将一个已经存在的表修改成其他的存储引擎。
一. MyISAM(P134)
MyISAM不支持事务,不支持外键,其优势是访问速度块,对事务完整性没有要求或者以SELECT、INSERT为主的应用基本上都可以使用这个引擎来创建表。
每个MyISAM在磁盘上存储为3个文件,其文件名都和表名相同,但拓展名分别为:
- .frm(存储表定义);
- .MYD(MYData,存储数据);
- .MYI(MYIndex,存储索引)。
数据文件和索引文件可以放在不同的目录,平均分布IO,获得更快的速度。
MyISAM表还支持3种不同的存储格式,分别是:
- 静态(固定长度)表;
- 动态表;
- 压缩表。
静态表是默认的存储格式,其中的字段都是非变长字段,这样每个记录的长度都是固定的,优点是存储速度非常迅速,容易缓存,出现故障容易恢复;缺点是占用的空间通常比动态表多。静态表的数据在存储时会按照列的宽度定义补足空格,然后在获取的时候将最后的空格全部去掉。
动态表中包含变长字段,记录不是固定长度的,这样存储的优点是占用的空间少,但频繁的更新和删除记录会产生碎片,需要定期执行OPTIMIZE TABLE语句或者myisamchk-r命令来改善性能,并且在出现故障时恢复相对困难。
压缩表由myisampack工具创建,占据非常小的磁盘空间。因为每个记录是被单独压缩的,所有只有非常小的访问开支。
二. InnoDB(P136)
InnoDB表的自动增长列可以手工插入,但是插入的值如果是空或者0,则实际插入的将是自动增长后的值。
可以通过ALTER TABLE table_name ATUO_INCREMENT=n;语句强制设置自动增长列的初始值,默认从1开始,但是该强制的默认值是保留在内存中的,如果该值在使用之前数据库重启,那么这个强制的默认值就会丢失,就需要在数据库启动以后重新设置。
可以使用select LAST_INSERT_ID();查询当前线程最后插入记录使用的值。如果一次插入了多条记录,那么返回的是第一条记录使用的自动增长值。
对于InnoDB表,自动增长列必须是索引列。如果是组合索引,也必须是组合索引的第一列,但是对于MyISAM表,自动增长列可以是组合索引的其他列,这样插入记录后,自动增长列是按照组合索引的前面几列进行排序后递增的。