加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

SQLite 自动增长

发布时间:2020-12-12 20:12:27 所属栏目:百科 来源:网络整理
导读:对于SQLite主键数据类型为 int 类型。 插入的时候,不传入数据, 就是默认为自动递增处理。 last_insert_rowid() 函数用于获取最新生成的 IDsqlite CREATE TABLE test_create_tab2 ( ... id integer,... val VARCHAR(10),... PRIMARY KEY (id) ... );sqlite
对于SQLite
主键数据类型为 int 类型。 
插入的时候,不传入数据, 就是默认为自动递增处理。 
last_insert_rowid()  函数用于获取最新生成的 ID

sqlite> CREATE TABLE test_create_tab2 (
   ...>   id   integer,...>   val  VARCHAR(10),...>   PRIMARY KEY (id)
   ...> );
sqlite>  INSERT INTO test_create_tab2(val) VALUES ('NO id');
sqlite> select last_insert_rowid();
last_insert_rowid()
1

sqlite> INSERT INTO test_create_tab2(val) VALUES ('NO id 2');
sqlite> select last_insert_rowid();
last_insert_rowid()
2

sqlite> select * from test_create_tab2;
id|val
1|NO id
2|NO id 2

sqlite> INSERT INTO test_create_tab2(id,val) VALUES (100,'id is 100');
sqlite> INSERT INTO test_create_tab2(val) VALUES ('NO id again');
sqlite> select * from test_create_tab2;
id|val
1|NO id
2|NO id 2
100|id is 100
101|NO id again

注意:
对于无主键的表
SQLite  中还有一个 伪列 rowid,可以作为自动递增的查询处理。
 
sqlite> CREATE TABLE test_create_tab3 (
   ...>   id   integer,...>   val  VARCHAR(10)
   ...> );
sqlite>
sqlite> INSERT INTO test_create_tab3(id,val) VALUES (1,'Test1');
sqlite> INSERT INTO test_create_tab3(id,val) VALUES (2,'Test2');
sqlite> INSERT INTO test_create_tab3(id,'Test100');
sqlite> INSERT INTO test_create_tab3(id,val) VALUES (101,'Test101');
sqlite> select rowid,id,val from test_create_tab3;
rowid|id|val
1|1|Test1
2|2|Test2
3|100|Test100
4|101|Test101

(1) 如何建立自动增长字段? 
简短回答:声明为 INTEGER PRIMARY KEY 的列将会自动增长。 
长一点的答案: 如果你声明表的一列为 INTEGER PRIMARY KEY,那么, 每当你在该列上插入一NULL值时, NULL自动被转换为一个比该列中最大值大1的一个整数,如果表是空的, 将会是1。 (如果是最大可能的主键 9223372036854775807,那个,将键值将是随机未使用的数。) 如,有下列表:
CREATE TABLE t1( 
a INTEGER PRIMARY KEY,b INTEGER 
); 
在该表上,下列语句 
INSERT INTO t1 VALUES(NULL,123); 
在逻辑上等价于: 
INSERT INTO t1 VALUES((SELECT max(a) FROM t1)+1,123); 
有一个新的API叫做 sqlite3_last_insert_rowid(), 它将返回最近插入的整数值。 
注意该整数会比表中该列上的插入之前的最大值大1。该键值在当前的表中是唯一的。但有可能与已从表中删除的值重叠。要想建立在整个表的生命周期中唯一的键值,需要在 INTEGER PRIMARY KEY 上增加AUTOINCREMENT声明。那么,新的键值将会比该表中曾能存在过的最大值大1。如果最大可能的整数值在数据表中曾经存在过,INSERT将会失败, 并返回SQLITE_FULL错误代码。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读