「SQLite学习笔记」 Autoincrement(自动递增)

发布时间:2018-11-15  栏目:sqlite  评论:0 Comments

SQLite 的 AUTOINCREMENT
是一个要字,用于表中的字段值自动递增。我们可以于开创表时于一定的列名称达到动
AUTOINCREMENT 关键字贯彻该字段值的机关增加。

SQLite 的 AUTOINCREMENT
是一个至关重要字,用于表中的许段值自动递增。我们得在创造表时在特定的列名称上行使
AUTOINCREMENT 关键字贯彻该字段值的电动增加。

注意点:整型字段可以用要字AUTOINCREMENT。

要害字 AUTOINCREMENT 只能用来整型(INTEGER)字段。

语法

语法

AUTOINCREMENT关键字的主导用法如下:

AUTOINCREMENT 关键字的核心用法如下:

CREATE TABLE table_name(
  column1 INTEGER AUTOINCREMENT,
  column2 datatype,
  column3 datatype,
  .....
  columnN datatype,
);

CREATE TABLE table_name(

column1 INTEGER AUTOINCREMENT,

column2 datatype,

column3 datatype,

…..

columnN datatype,

);

例子:

实例

考虑COMPANY表要创造如下:

若要创的 COMPANY 表如下所示:

sqlite> CREATE TABLE COMPANY(
  ID INTEGER PRIMARY KEY  AUTOINCREMENT,
  NAME      TEXT   NOT NULL,
  AGE      INT    NOT NULL,
  ADDRESS    CHAR(50),
  SALARY     REAL
);

sqlite> CREATE TABLE COMPANY(

ID INTEGER PRIMARY KEY AUTOINCREMENT,

NAME TEXT NOT NULL,

AGE INT NOT NULL,

ADDRESS CHAR(50),

SALARY REAL

);

现今,以下记录插入到表 COMPANY:

而今,向 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 );

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将起以下记录:

立即将朝着 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

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

私了解:

参考:http://www.w3cschool.cc/sqlite/sqlite-autoincrement.html

1.数据库插入字段:

图片 1

AUTOINCREMENT(自增字段)不能够重复使用删除的字段的id值,保证了id必须唯一;
rowid是摸索就存在的无比要命rowid+1,有或rowid+1(当前底rowid)之前让剔除了;

2.数据库rowid到达最老后:

AUTOINCREMENT(自添字段)会回到SQLITE_FULL错误码;
rowid新值会在这极充分累前随机找一个没有让利用字段的id值,可能是事先受删去了的字段;

乃可能感兴趣之篇章:

  • Sqlite数据库里安插入数据的条数上限是500
  • SQLite教程(八):命令行工具介绍
  • SQLite教程(十二):锁和出现控制详解
  • SQLite教程(十四):C语言编程实例代码(2)
  • python查询sqlite数据表的不二法门

留下评论

网站地图xml地图