源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

SQLite之Autoincrement关键字(自动递增)

  • 时间:2022-09-01 19:47 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:SQLite之Autoincrement关键字(自动递增)
SQLite 的 AUTOINCREMENT 是一个关键字,用于表中的字段值自动递增。我们可以在创建表时在特定的列名称上使用 AUTOINCREMENT 关键字实现该字段值的自动增加。 注意点:整型字段可以使用关键字AUTOINCREMENT。 语法 AUTOINCREMENT关键字的基本用法如下:
CREATE TABLE table_name(
  column1 INTEGER AUTOINCREMENT,
  column2 datatype,
  column3 datatype,
  .....
  columnN datatype,
);
例子: 考虑COMPANY表要创建如下:
sqlite> CREATE TABLE COMPANY(
  ID INTEGER PRIMARY KEY  AUTOINCREMENT,
  NAME      TEXT   NOT NULL,
  AGE      INT    NOT NULL,
  ADDRESS    CHAR(50),
  SALARY     REAL
);
现在,以下记录插入到表 COMPANY:
INSERT INTO COMPANY (NAME,AGE,ADDRESS,SALARY)
VALUES ( 'Paul', 32, 'California', 20000.00 );
INSERT INTO COMPANY (NAME,AGE,ADDRESS,SALARY)
VALUES ('Allen', 25, 'Texas', 15000.00 );
INSERT INTO COMPANY (NAME,AGE,ADDRESS,SALARY)
VALUES ('Teddy', 23, 'Norway', 20000.00 );
INSERT INTO COMPANY (NAME,AGE,ADDRESS,SALARY)
VALUES ( 'Mark', 25, 'Rich-Mond ', 65000.00 );
INSERT INTO COMPANY (NAME,AGE,ADDRESS,SALARY)
VALUES ( 'David', 27, 'Texas', 85000.00 );
INSERT INTO COMPANY (NAME,AGE,ADDRESS,SALARY)
VALUES ( 'Kim', 22, 'South-Hall', 45000.00 );
INSERT INTO COMPANY (NAME,AGE,ADDRESS,SALARY)
VALUES ( 'James', 24, 'Houston', 10000.00 );
这将插入到表COMPANY 7个元组,COMPANY将有以下记录: ID          NAME        AGE         ADDRESS     SALARY ----------  ----------  ----------  ----------  ---------- 1           Paul        32          California  20000.0 2           Allen       25          Texas       15000.0 3           Teddy       23          Norway      20000.0 4           Mark        25          Rich-Mond   65000.0 5           David       27          Texas       85000.0 6           Kim         22          South-Hall  45000.0 7           James       24          Houston     10000.0 个人理解: 1.数据库插入字段: AUTOINCREMENT(自增加字段)不能重复使用删除的字段的id值,保证了id必须唯一; rowid是找已存在的最大rowid+1,有可能rowid+1(当前的rowid)之前被删除过; 2.数据库rowid到达最大之后: AUTOINCREMENT(自增加字段)会返回SQLITE_FULL错误码; rowid新值会在这个最大数之前随机找一个没被使用字段的id值,可能是之前被删除过的字段;
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部