SQLite Autoincrement

SQLite 的 AUTOINCREMENT 是一个关键字,用于表中的字段值自动递增。我们可以在创建表时在特定的列名称上使用 AUTOINCREMENT 关键字实现该字段值的自动增加。

关键字 AUTOINCREMENT 只能用于整型(INTEGER)字段。

语法

AUTOINCREMENT 关键字的基本用法如下:

  1. CREATE TABLE table_name(
  2. column1 INTEGER AUTOINCREMENT,
  3. column2 datatype,
  4. column3 datatype,
  5. .....
  6. columnN datatype,
  7. );

实例

假设要创建的 COMPANY 表如下所示:

  1. sqlite> CREATE TABLE COMPANY(
  2. ID INTEGER PRIMARY KEY AUTOINCREMENT,
  3. NAME TEXT NOT NULL,
  4. AGE INT NOT NULL,
  5. ADDRESS CHAR(50),
  6. SALARY REAL
  7. );

现在,向 COMPANY 表插入以下记录:

  1. INSERT INTO COMPANY (NAME,AGE,ADDRESS,SALARY)
  2. VALUES ( 'Paul', 32, 'California', 20000.00 );
  3. INSERT INTO COMPANY (NAME,AGE,ADDRESS,SALARY)
  4. VALUES ('Allen', 25, 'Texas', 15000.00 );
  5. INSERT INTO COMPANY (NAME,AGE,ADDRESS,SALARY)
  6. VALUES ('Teddy', 23, 'Norway', 20000.00 );
  7. INSERT INTO COMPANY (NAME,AGE,ADDRESS,SALARY)
  8. VALUES ( 'Mark', 25, 'Rich-Mond ', 65000.00 );
  9. INSERT INTO COMPANY (NAME,AGE,ADDRESS,SALARY)
  10. VALUES ( 'David', 27, 'Texas', 85000.00 );
  11. INSERT INTO COMPANY (NAME,AGE,ADDRESS,SALARY)
  12. VALUES ( 'Kim', 22, 'South-Hall', 45000.00 );
  13. INSERT INTO COMPANY (NAME,AGE,ADDRESS,SALARY)
  14. VALUES ( 'James', 24, 'Houston', 10000.00 );

这将向 COMPANY 表插入 7 个元组,此时 COMPANY 表的记录如下:

  1. ID NAME AGE ADDRESS SALARY
  2. ---------- ---------- ---------- ---------- ----------
  3. 1 Paul 32 California 20000.0
  4. 2 Allen 25 Texas 15000.0
  5. 3 Teddy 23 Norway 20000.0
  6. 4 Mark 25 Rich-Mond 65000.0
  7. 5 David 27 Texas 85000.0
  8. 6 Kim 22 South-Hall 45000.0
  9. 7 James 24 Houston 10000.0