SQL AUTO INCREMENT 字段介绍

来源:网络时间:2017-03-09

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

  我们可以在表中创建一个 auto-increment 字段。


  用于 MySQL 的语法

  下列 SQL 语句把 "Persons" 表中的 "P_Id" 列定义为 auto-increment 主键:

  CREATE TABLE Persons

  (

  P_Id int NOT NULL AUTO_INCREMENT,

  LastName varchar(255) NOT NULL,

  FirstName varchar(255),

  Address varchar(255),

  City varchar(255),

  PRIMARY KEY (P_Id)

  )

  MySQL 使用 AUTO_INCREMENT 关键字来执行 auto-increment 任务。

  默认地,AUTO_INCREMENT 的开始值是 1,每条新记录递增 1。

  要让 AUTO_INCREMENT 序列以其他的值起始,请使用下列 SQL 语法:

  ALTER TABLE Persons AUTO_INCREMENT=100

  要在 "Persons" 表中插入新记录,我们不必为 "P_Id" 列规定值(会自动添加一个唯一的值):

  INSERT INTO Persons (FirstName,LastName)

  VALUES ('Bill','Gates')

  上面的 SQL 语句会在 "Persons" 表中插入一条新记录。"P_Id" 会被赋予一个唯一的值。"FirstName" 会被设置为 "Bill","LastName" 列会被设置为 "Gates"。


  用于 SQL Server 的语法

  下列 SQL 语句把 "Persons" 表中的 "P_Id" 列定义为 auto-increment 主键:

  CREATE TABLE Persons

  (

  P_Id int PRIMARY KEY IDENTITY,

  LastName varchar(255) NOT NULL,

  FirstName varchar(255),

  Address varchar(255),

  City varchar(255)

  )

  MS SQL 使用 IDENTITY 关键字来执行 auto-increment 任务。

  默认地,IDENTITY 的开始值是 1,每条新记录递增 1。

  要规定 "P_Id" 列以 20 起始且递增 10,请把 identity 改为 IDENTITY(20,10)

  要在 "Persons" 表中插入新记录,我们不必为 "P_Id" 列规定值(会自动添加一个唯一的值):

  INSERT INTO Persons (FirstName,LastName)

  VALUES ('Bill','Gates')

  上面的 SQL 语句会在 "Persons" 表中插入一条新记录。"P_Id" 会被赋予一个唯一的值。"FirstName" 会被设置为 "Bill","LastName" 列会被设置为 "Gates"。

发表评论

最新评论(共0条)