翻译:https://www.sqlite.org/autoinc.html
 
概述
1 自增主键(TheAUTOINCREMENT keyword)占用额外CPU,内存,磁盘空间,并且增加磁盘I/O的开销(disk I/O overhead),所以如无必要,应该禁用。通常情况下是不需要的。
2 SQLite中,指定其中的一列的属性为INTEGERPRIMARY KEY,和指定为ROWID,效果是一样的(an alias for the ROWID),(除非在创建表的时候,指定了WITHOUT_ROWID),存储类型是64位符号整型。
3 在插入操作中,如果ROWID或者INTEGERPRIMARY KEY列没有指定值,SQLITE将会自动填充一个没有使用的整型,通常大于已经使用的任何一个ROWID值。不管是否已经指定了AUTOINCREMENT关键字,效果还是一样。
4 如果AUTOINCREMENT关键字紧随INTEGEPRIMARY KEY关键字,将会改变ROWID的分配算法,不再使用已经被使用的ROWID值,换句话说,就是AUTOINCREMENT将阻止ROWID的重用,尽管该ROWID已经随着某一行的数据删除,而没有被使用。
 
背景
对于SQLite来说,每一个表的每一行都会有一个64位符号整型ROWID,该ROWID在该表中唯一表示(指定了WITHOUT_ROWID表例外)