加入收藏 | 设为首页 | 会员中心 | 我要投稿 银川站长网 (https://www.0951zz.com/)- 云通信、基础存储、云上网络、机器学习、视觉智能!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

数据库中Autoincrement关键字用来做什么 咋用

发布时间:2023-05-27 11:07:54 所属栏目:MsSql教程 来源:
导读:今天这篇我们来学习和了解“数据库中Autoincrement关键字用来做什么,怎么用”,下文的讲解详细,步骤过程清晰,对大家进一步学习和理解“数据库中Autoincrement关键字用来做什么,怎么用”有一

今天这篇我们来学习和了解“数据库中Autoincrement关键字用来做什么,怎么用”,下文的讲解详细,步骤过程清晰,对大家进一步学习和理解“数据库中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值,可能是之前被删除过的字段。

(编辑:银川站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章