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

前端之家收集整理的这篇文章主要介绍了SQLite之Autoincrement关键字(自动递增)前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

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

语法

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

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

例子:

考虑COMPANY表要创建如下:

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

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

sql;"> INSERT INTO COMPANY (NAME,AGE,ADDRESS,SALARY) VALUES ( 'Paul',32,'California',20000.00 ); INSERT INTO COMPANY (NAME,SALARY) VALUES ('Allen',25,'Texas',15000.00 ); INSERT INTO COMPANY (NAME,SALARY) VALUES ('Teddy',23,'Norway',SALARY) VALUES ( 'Mark','Rich-Mond ',65000.00 ); INSERT INTO COMPANY (NAME,SALARY) VALUES ( 'David',27,85000.00 ); INSERT INTO COMPANY (NAME,SALARY) VALUES ( 'Kim',22,'South-Hall',45000.00 ); INSERT INTO COMPANY (NAME,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值,可能是之前被删除过的字段;

原文链接:https://www.f2er.com/mssql/62969.html

猜你在找的MsSQL相关文章