菜单

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

2018年11月16日 - sqlite

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值,可能是事先受删去了之字段;

汝或许感兴趣的篇章:

相关文章

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图