SQLITE数据表主键设置Id自增方法
2013-03-20 17:29
429 查看
搞定了一个困扰许久的问题,原来sqlite中的主键也是可以设置为自增的:)方法就是声明为 INTEGER PRIMARY KEY 的字段可以自动增加。
网上查到资料说,从 SQLite 的 2.3.4 版本开始,如果将一个表中的一个字段声明为 INTEGER PRIMARY KEY,那么只需向该表的该字段插入一个 NULL 值,这个 NULL 值将自动被更换为比表中该字段所有行的最大值大 1 的整数;如果表为空,那么将被更换为 1。
CREATE TABLE "ProcessList"(
[Id] integer(4) PRIMARY KEY
,[Type] varchar(20)
,[Name] varchar(30)
,[IsUse] int
)
执行
insert into processlist
values
(null,'a','b',1)
在逻辑意义上等价于:
insert into processlist VALUES((SELECT max(Id) FROM processlist)+1, 'a','b',1);
insert into processlist
values
(null,'aa','bb',1)
执行两条插入语句后再查询表中数据:
select * from processlist
结果如下:
Id Type Name IsUse
1 a b 1
2 aa bb 1
一个新的API函数 sqlite3_last_insert_rowid() 返回最近的插入操作的整形键.注意这个整型键始终比之前插入表中的最后一个键大1。新键相对于表中的已有键来说是唯一的, 但它可能与之前从表中删除的键值重叠。要始终得到在整个表中唯一的键,在INTEGER PRIMARY KEY的声明之前加关键词AUTOINCREMENT.这样被选的键将总是比表中已存在的最大键大1。若可能的最大键已存在于表中,INSERT操作将失败并返回一个SQLITE_FULL错误码.
网上查到资料说,从 SQLite 的 2.3.4 版本开始,如果将一个表中的一个字段声明为 INTEGER PRIMARY KEY,那么只需向该表的该字段插入一个 NULL 值,这个 NULL 值将自动被更换为比表中该字段所有行的最大值大 1 的整数;如果表为空,那么将被更换为 1。
CREATE TABLE "ProcessList"(
[Id] integer(4) PRIMARY KEY
,[Type] varchar(20)
,[Name] varchar(30)
,[IsUse] int
)
执行
insert into processlist
values
(null,'a','b',1)
在逻辑意义上等价于:
insert into processlist VALUES((SELECT max(Id) FROM processlist)+1, 'a','b',1);
insert into processlist
values
(null,'aa','bb',1)
执行两条插入语句后再查询表中数据:
select * from processlist
结果如下:
Id Type Name IsUse
1 a b 1
2 aa bb 1
一个新的API函数 sqlite3_last_insert_rowid() 返回最近的插入操作的整形键.注意这个整型键始终比之前插入表中的最后一个键大1。新键相对于表中的已有键来说是唯一的, 但它可能与之前从表中删除的键值重叠。要始终得到在整个表中唯一的键,在INTEGER PRIMARY KEY的声明之前加关键词AUTOINCREMENT.这样被选的键将总是比表中已存在的最大键大1。若可能的最大键已存在于表中,INSERT操作将失败并返回一个SQLITE_FULL错误码.
相关文章推荐
- SQLITE数据表主键设置Id自增方法
- SQLITE数据表主键设置Id自增方法
- SQLITE数据表主键设置Id自增方法
- SQLITE数据表主键设置Id自增方法
- SQLITE数据表主键设置Id自增方法
- SQLITE数据表主键设置Id自增方法
- SQLITE数据表主键设置Id自增方法
- SQLITE数据表主键设置Id自增方法
- mysql中不清除表里的数据重新设置自增的id的方法
- THINKPHP在添加数据的时候获取主键id的值方法
- SQLite设置_id自增的方法
- mysql 主键id自增长,插入数据的方法
- mysql中不清除表里的数据重新设置自增的id的方法
- 最全iOS数据存储方法介绍:FMDB,SQLite3 ,Core Data,Plist,Preference偏好设置,NSKeyedArchiver归档
- 数据库插入数据返回当前主键ID值方法
- sqlite 中主键id自增的方法
- SQLite 获取最新插入数据的自增长主键ID
- C#中使用MySqlCommand执行插入语句后获取该数据主键id值的方法
- Mybatis中,当插入数据后,返回最新主键id的几种方法,及具体用法
- Mybatis中,当插入数据后,返回最新主键id的几种方法,及具体用法