• SQL ALTER TABLE 语句||SQL AUTO INCREMENT 字段


    SQL ALTER TABLE 语句


    ALTER TABLE 语句

     ALTER TABLE 语句用于在现有表中添加、删除或修改列。

    SQL ALTER TABLE 语法

     若要向表中添加列,请使用以下语法:

    1. ALTER TABLE table_name
    2. ADD column_name datatype

     若要删除表中的列,请使用以下语法(请注意,一些数据库系统不允许这样删除数据库表中的列):

    1. ALTER TABLE table_name
    2. DROP COLUMN column_name

     若要更改表中列的数据类型,请使用以下语法:

    SQL Server / MS Access:

    1. ALTER TABLE table_name
    2. ALTER COLUMN column_name datatype

    My SQL / Oracle:

    1. ALTER TABLE table_name
    2. MODIFY COLUMN column_name datatype


    SQL ALTER TABLE 实例

     请看 "Persons" 表:

    P_IdLastNameFirstNameAddressCity
    1HansenOlaTimoteivn 10Sandnes
    2SvendsonToveBorgvn 23Sandnes
    3PettersenKariStorgt 20Stavanger

     现在,我们想在 "Persons" 表中添加一个名为 "DateOfBirth" 的列。

     我们使用下面的 SQL 语句:

    1. ALTER TABLE Persons
    2. ADD DateOfBirth date

     请注意,新列 "DateOfBirth" 的类型是 date,可以存放日期。数据类型规定列中可以存放的数据的类型。如需了解 MS Access、MySQL 和 SQL Server 中可用的数据类型,请访问我们完整的 数据类型参考手册

     现在,"Persons" 表将如下所示:

    P_IdLastNameFirstNameAddressCityDateOfBirth
    1HansenOlaTimoteivn 10Sandnes
    2SvendsonToveBorgvn 23Sandnes
    3PettersenKariStorgt 20Stavanger


    改变数据类型实例

     现在,我们想要改变 "Persons" 表中 "DateOfBirth" 列的数据类型。

     我们使用下面的 SQL 语句:

    1. ALTER TABLE Persons
    2. ALTER COLUMN DateOfBirth year

     请注意,现在 "DateOfBirth" 列的类型是 year,可以存放 2 位或 4 位格式的年份。


    DROP COLUMN 实例

     接下来,我们想要删除 "Person" 表中的 "DateOfBirth" 列。

     我们使用下面的 SQL 语句:

    1. ALTER TABLE Persons
    2. DROP COLUMN DateOfBirth

     现在,"Persons" 表将如下所示:

    P_IdLastNameFirstNameAddressCity
    1HansenOlaTimoteivn 10Sandnes
    2SvendsonToveBorgvn 23Sandnes
    3PettersenKariStorgt 20Stavanger

    SQL AUTO INCREMENT 字段


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

    AUTO INCREMENT 字段


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

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

    用于 MySQL 的语法


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

    1. CREATE TABLE Persons
    2. (
    3. ID int NOT NULL AUTO_INCREMENT,
    4. LastName varchar(255) NOT NULL,
    5. FirstName varchar(255),
    6. Address varchar(255),
    7. City varchar(255),
    8. PRIMARY KEY (ID)
    9. )

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

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

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

    ALTER TABLE Persons AUTO_INCREMENT=100       

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

    1. INSERT INTO Persons (FirstName,LastName)
    2. VALUES ('Lars','Monsen')

     上面的SQL语句在 "Persons" 表中插入一个新记录。“ID”栏将得到唯一值。"FirstName"栏设置为"Lars","LastName"栏设置为"Monsen"。

    用于 SQL Server 的语法


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

    1. CREATE TABLE Persons
    2. (
    3. ID int IDENTITY(1,1) PRIMARY KEY,
    4. LastName varchar(255) NOT NULL,
    5. FirstName varchar(255),
    6. Address varchar(255),
    7. City varchar(255)
    8. )

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

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

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

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

    1. INSERT INTO Persons (FirstName,LastName)
    2. VALUES ('Lars','Monsen')

     上面的 SQL 语句在 "Persons" 表中插入一个新记录。“ID”栏将得到唯一值。"FirstName"栏设置为"Lars","LastName"栏设置为"Monsen"。

    用于 Access 的语法


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

    1. CREATE TABLE Persons
    2. (
    3. ID Integer PRIMARY KEY AUTOINCREMENT,
    4. LastName varchar(255) NOT NULL,
    5. FirstName varchar(255),
    6. Address varchar(255),
    7. City varchar(255)
    8. )

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

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

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

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

    1. INSERT INTO Persons (FirstName,LastName)
    2. VALUES ('Lars','Monsen')

     上面的 SQL 语句在 "Persons" 表中插入一个新记录。“ID”栏将得到唯一值。"FirstName"栏设置为"Lars","LastName"栏设置为"Monsen"。

    语法 for Oracle


     在 Oracle 中,代码有点复杂。

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

     使用以下CREATSEQUENT语法:

    1. CREATE SEQUENCE seq_person
    2. MINVALUE 1
    3. START WITH 1
    4. INCREMENT BY 1
    5. CACHE 10

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

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

    1. INSERT INTO Persons (ID,FirstName,LastName)
    2. VALUES (seq_person.nextval,'Lars','Monsen')

     上面的SQL语句在 "Persons" 表中插入一个新记录。"ID" 列从 seq_person 序列中分配下一个数字。"FirstName"栏设置为"Lars","LastName"栏设置为"Monsen"。

  • 相关阅读:
    计算机毕业设计springboot+vue基本微信小程序的汽车租赁公司小程序
    【Netty】自定义解码器、编码器、编解码器(十五)
    用友YonSuite“数智飞轮”用场景化告别产品与客户间的“翻译”
    linux - 云架构理论基础
    [附源码]SSM计算机毕业设计视屏网站论文JAVA
    vscode 快速生成标准javabean
    HTML期末学生大作业-节日网页作业html+css+javascript
    WIinform 跨线程修改
    k8s存储卷 PV和PVC
    2023年11月25日(星期六)骑行三家村
  • 原文地址:https://blog.csdn.net/m0_69824302/article/details/134471182