SQL基础知识普及(二十)——AUTO INCREMENT 字段

简介: SQL数据库开发

 

Auto-increment 会在新记录插入表中时生成一个唯一的数字。

AUTO INCREMENT 字段

我们通常希望在每次插入新记录时自动创建主键字段的值。

我们可以在表中创建一个自动增量(auto-increment)字段。

用于 MySQL 的语法

以下SQL语句将 "Persons" 表中的“ID”列定义为自动递增(auto-increment)主键字段:

CREATE TABLE Persons

(

ID int NOT NULL AUTO_INCREMENT,

姓名 varchar(255) NOT NULL,

地址 varchar(255),

城市 varchar(255),

省份 varchar(255),

PRIMARY KEY (ID)

)

MySQL使用AUTO_INREMENT关键字来执行自动增量( auto-increment )任务。

默认情况下,AUTO_INREMENT的起始值为1,每个新记录增加1。

若要以其他值开始AUTO_INREMENT序列,请使用以下SQL语法:

ALTER TABLE Persons AUTO_INCREMENT=100

要在 "Persons" 表中插入新记录,我们不需要为"ID"栏指定值(自动添加唯一值):

INSERT INTO Persons (姓名,城市)

VALUES ('宋江','蓬莱市')

上面的SQL语句在 "Persons" 表中插入一个新记录。“ID”栏将得到唯一值。"姓名"栏设置为"宋江","城市"栏设置为"蓬莱市"。

用于 SQL Server 的语法

以下SQL语句将 "Persons" 表中的“ID”列定义为自动递增( auto-increment )主键字段:

CREATE TABLE Persons

(

ID int IDENTITY(1,1) PRIMARY KEY,

姓名 varchar(255) NOT NULL,

地址 varchar(255),

城市 varchar(255),

省份 varchar(255)

)

MS SQL Server使用IDENTITY关键字执行自动增量( auto-increment )任务。

在上面的示例中,IDENTITY的起始值为1,每个新记录增量为1。

提示:指定“ID”列以10开头,并递增5,将标识( identity )更改为IDENTITY(105)。

要在 "Persons" 表中插入新记录,我们不需要为"ID"栏指定值(自动添加唯一值):

INSERT INTO Persons (姓名,城市)

VALUES ('宋江','蓬莱市')

上面的 SQL 语句在 "Persons" 表中插入一个新记录。“ID”栏将得到唯一值。"姓名"栏设置为"宋江","城市"栏设置为"蓬莱市"。

用于 Access 的语法

以下 SQL 语句将 "Persons" 表中的“ID”列定义为自动递增( auto-increment )主键字段:

CREATE TABLE Persons

(

ID Integer PRIMARY KEY AUTOINCREMENT,

姓名 varchar(255) NOT NULL,

地址 varchar(255),

城市 varchar(255),

省份 varchar(255)

)

MS Access使用 AUTOINCREMENT 关键字执行自动增量( auto-increment )任务。

默认情况下,AUTOINCREMEN的起始值为1,每个新记录递增 1。

提示:指定“ID”栏以10开头,并递增5,将自动递增( autoincrement )更改为自动递增(105)( AUTOINCREMENT(10,5))。

要在 "Persons" 表中插入新记录,我们不需要为"ID"栏指定值(自动添加唯一值):

INSERT INTO Persons (姓名,城市)

VALUES ('宋江','蓬莱市')

上面的 SQL 语句在 "Persons" 表中插入一个新记录。“ID”栏将得到唯一值。"姓名"栏设置为"宋江","城市"栏设置为"蓬莱市"。

在 Oracle 中,代码有点复杂。

您必须使用序列( sequence )对象(该对象生成数字序列)创建自动增量( auto-increment )字段。

使用以下CREATSEQUENT语法:

CREATE SEQUENCE seq_person

MINVALUE 1

START WITH 1

INCREMENT BY 1

CACHE 10

上面的代码创建了一个名为seq_pean的序列( sequence) 对象,它以1开头,以1递增。此对象缓存10个值以提高性能。缓存选项指定要存储多少序列值以提高访问速度。

要在"Persons" 表中插入新记录,我们必须使用nextval函数,该函数从seq_hor序列检索下一个值:

INSERT INTO Persons (ID,姓名,城市)

VALUES (seq_person.nextval,'宋江','蓬莱市')

上面的SQL语句在 "Persons" 表中插入一个新记录。"ID" 列从 seq_person 序列中分配下一个数字。"姓名"栏设置为"宋江","城市"栏设置为"蓬莱市"。

相关文章
|
2月前
|
SQL
SQL语句两个字段或多个字段同时order by 排序
SQL语句两个字段或多个字段同时order by 排序
30 0
|
3月前
|
SQL JSON 关系型数据库
sql如何获取字段里的json值
sql如何获取字段里的json值
|
3月前
|
SQL
Sql语法:字段不为空
Sql语法:字段不为空
|
4月前
|
SQL Oracle 关系型数据库
Oracle PL/SQL基础知识及应用案例
Oracle PL/SQL基础知识及应用案例
33 0
|
4月前
|
SQL Oracle 关系型数据库
sql语句两个字段合并或者两个字段拼接显示
sql语句两个字段合并或者两个字段拼接显示
|
5月前
|
SQL 关系型数据库 PostgreSQL
PostgreSQL【SQL 01】根据条件更新字段值或追加信息STRPOS(string, substring)函数使用及LIKE函数对比
PostgreSQL【SQL 01】根据条件更新字段值或追加信息STRPOS(string, substring)函数使用及LIKE函数对比
59 0
|
5月前
|
SQL 关系型数据库 MySQL
SQL编程【MySQL 01】拆分列字段为行并根据类型翻译字段 > 1305 - FUNCTION x.help_topic_id does not exist 报错问题
SQL编程【MySQL 01】拆分列字段为行并根据类型翻译字段 > 1305 - FUNCTION x.help_topic_id does not exist 报错问题
36 0
|
22天前
|
SQL 人工智能 算法
【SQL server】玩转SQL server数据库:第二章 关系数据库
【SQL server】玩转SQL server数据库:第二章 关系数据库
61 10
|
1月前
|
SQL
启动mysq异常The server quit without updating PID file [FAILED]sql/data/***.pi根本解决方案
启动mysq异常The server quit without updating PID file [FAILED]sql/data/***.pi根本解决方案
30 0
|
1月前
|
SQL 关系型数据库 MySQL
SQL Error (2013): Lost connection to MySQL server at 'waiting for initial communication packet', sys...
SQL Error (2013): Lost connection to MySQL server at 'waiting for initial communication packet', sys...