SQLite中Autoincrement关键字如何使用
这篇文章给大家介绍SQLite中Autoincrement关键字如何使用,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。
SQLite 的 AUTOINCREMENT 是一个关键字,用于表中的字段值自动递增。我们可以在创建表时在特定的列名称上使用 AUTOINCREMENT 关键字实现该字段值的自动增加。
注意点:整型字段可以使用关键字AUTOINCREMENT。
语法
AUTOINCREMENT关键字的基本用法如下:
CREATETABLEtable_name(column1INTEGERAUTOINCREMENT,column2datatype,column3datatype,.....columnNdatatype,);
例子:
考虑COMPANY表要创建如下:
sqlite>CREATETABLECOMPANY(IDINTEGERPRIMARYKEYAUTOINCREMENT,NAMETEXTNOTNULL,AGEINTNOTNULL,ADDRESSCHAR(50),SALARYREAL);
现在,以下记录插入到表 COMPANY:
INSERTINTOCOMPANY(NAME,AGE,ADDRESS,SALARY)VALUES('Paul',32,'California',20000.00);INSERTINTOCOMPANY(NAME,AGE,ADDRESS,SALARY)VALUES('Allen',25,'Texas',15000.00);INSERTINTOCOMPANY(NAME,AGE,ADDRESS,SALARY)VALUES('Teddy',23,'Norway',20000.00);INSERTINTOCOMPANY(NAME,AGE,ADDRESS,SALARY)VALUES('Mark',25,'Rich-Mond',65000.00);INSERTINTOCOMPANY(NAME,AGE,ADDRESS,SALARY)VALUES('David',27,'Texas',85000.00);INSERTINTOCOMPANY(NAME,AGE,ADDRESS,SALARY)VALUES('Kim',22,'South-Hall',45000.00);INSERTINTOCOMPANY(NAME,AGE,ADDRESS,SALARY)VALUES('James',24,'Houston',10000.00);
这将插入到表COMPANY 7个元组,COMPANY将有以下记录:
ID NAME AGE ADDRESS SALARY---------- ---------- ---------- ---------- ----------1 Paul 32 California 20000.02 Allen 25 Texas 15000.03 Teddy 23 Norway 20000.04 Mark 25 Rich-Mond 65000.05 David 27 Texas 85000.06 Kim 22 South-Hall 45000.07 James 24 Houston 10000.0
个人理解:
1.数据库插入字段:
AUTOINCREMENT(自增加字段)不能重复使用删除的字段的id值,保证了id必须唯一;rowid是找已存在的最大rowid+1,有可能rowid+1(当前的rowid)之前被删除过;
2.数据库rowid到达最大之后:
AUTOINCREMENT(自增加字段)会返回SQLITE_FULL错误码;rowid新值会在这个最大数之前随机找一个没被使用字段的id值,可能是之前被删除过的字段;
关于SQLite中Autoincrement关键字如何使用就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。