sqlite 的 AUTOINCREMENT 是一个关键字,用于表中的字段值自动递增。我们可以在创建表时在特定的列名称上使用 AUTOINCREMENT 关键字实现该字段值的自动增加。@H_301_1@
语法@H_301_1@
AUTOINCREMENT关键字的基本用法如下:
例子:
考虑COMPANY表要创建如下:
现在,以下记录插入到表 COMPANY:
这将插入到表COMPANY 7个元组,COMPANY将有以下记录:
ID NAME AGE ADDRESS SALARY@H_301_1@ ---------- ---------- ---------- ---------- ----------@H_301_1@ 1 Paul 32 California 20000.0@H_301_1@ 2 Allen 25 Texas 15000.0@H_301_1@ 3 Teddy 23 Norway 20000.0@H_301_1@ 4 Mark 25 Rich-Mond 65000.0@H_301_1@ 5 David 27 Texas 85000.0@H_301_1@ 6 Kim 22 South-Hall 45000.0@H_301_1@ 7 James 24 Houston 10000.0
1.数据库插入字段:
AUTOINCREMENT(自增加字段)不能重复使用删除的字段的id值,保证了id必须唯一;@H_301_1@ rowid是找已存在的最大rowid+1,有可能rowid+1(当前的rowid)之前被删除过;
2.数据库rowid到达最大之后:
AUTOINCREMENT(自增加字段)会返回sqlITE_FULL错误码;@H_301_1@ rowid新值会在这个最大数之前随机找一个没被使用字段的id值,可能是之前被删除过的字段;