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

SQL ALTER TABLE 语句


ALTER TABLE 语句

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

SQL ALTER TABLE 语法

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

复制代码
ALTER TABLE table_name                
ADD column_name datatype      

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

复制代码
ALTER TABLE table_name                
DROP COLUMN column_name      

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

SQL Server / MS Access:

复制代码
ALTER TABLE table_name                
ALTER COLUMN column_name datatype       

My SQL / Oracle:

复制代码
ALTER TABLE table_name                
MODIFY COLUMN column_name datatype        

SQL ALTER TABLE 实例

请看 "Persons" 表:

P_Id LastName FirstName Address City
1 Hansen Ola Timoteivn 10 Sandnes
2 Svendson Tove Borgvn 23 Sandnes
3 Pettersen Kari Storgt 20 Stavanger

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

我们使用下面的 SQL 语句:

复制代码
ALTER TABLE Persons                
ADD DateOfBirth date       

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

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

P_Id LastName FirstName Address City DateOfBirth
1 Hansen Ola Timoteivn 10 Sandnes
2 Svendson Tove Borgvn 23 Sandnes
3 Pettersen Kari Storgt 20 Stavanger

改变数据类型实例

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

我们使用下面的 SQL 语句:

复制代码
ALTER TABLE Persons                
ALTER COLUMN DateOfBirth year      

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


DROP COLUMN 实例

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

我们使用下面的 SQL 语句:

复制代码
ALTER TABLE Persons                
DROP COLUMN DateOfBirth        

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

P_Id LastName FirstName Address City
1 Hansen Ola Timoteivn 10 Sandnes
2 Svendson Tove Borgvn 23 Sandnes
3 Pettersen Kari Storgt 20 Stavanger

SQL AUTO INCREMENT 字段


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

AUTO INCREMENT 字段


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

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

用于 MySQL 的语法


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

复制代码
CREATE TABLE Persons                
(                
ID int NOT NULL AUTO_INCREMENT,                
LastName varchar(255) NOT NULL,                
FirstName varchar(255),                
Address varchar(255),                
City varchar(255),                
PRIMARY KEY (ID)                
)

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

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

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

复制代码
ALTER TABLE Persons AUTO_INCREMENT=100       

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

复制代码
INSERT INTO Persons (FirstName,LastName)                
VALUES ('Lars','Monsen')        

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

用于 SQL Server 的语法


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

复制代码
CREATE TABLE Persons                
(                
ID int IDENTITY(1,1) PRIMARY KEY,                
LastName varchar(255) NOT NULL,                
FirstName varchar(255),                
Address varchar(255),                
City varchar(255)                
)       

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

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

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

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

复制代码
INSERT INTO Persons (FirstName,LastName)                
VALUES ('Lars','Monsen')        

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

用于 Access 的语法


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

复制代码
CREATE TABLE Persons                
(                
ID Integer PRIMARY KEY AUTOINCREMENT,                
LastName varchar(255) NOT NULL,                
FirstName varchar(255),                
Address varchar(255),                
City varchar(255)                
)       

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

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

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

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

复制代码
INSERT INTO Persons (FirstName,LastName)                
VALUES ('Lars','Monsen')        

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

语法 for Oracle


在 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,FirstName,LastName)                
VALUES (seq_person.nextval,'Lars','Monsen')       

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

相关推荐
Dev7z18 分钟前
基于OpenCV的智能停车场车位识别与数据管理系统-支持MySQL持久化与Redis缓存加速
数据库·redis·缓存
小白量化1 小时前
聚宽策略分享-1年化98国九条后中小板微盘小改
大数据·数据库·人工智能·量化·qmt
DBA小马哥8 小时前
Oracle迁移实战:如何轻松跨越异构数据库的学习与技术壁垒
数据库·学习·oracle·信创·国产化平替
暮乘白帝过重山8 小时前
ArkTS ForEach 参数解析:组件与键值生成器
开发语言·数据库
一条咸鱼¥¥¥8 小时前
【运维经验】使用QQ邮箱SMTP服务器设置ssms计划任务完成时邮件发送
运维·服务器·经验分享·sql·sqlserver
菜鸟plus+9 小时前
N+1查询
java·服务器·数据库
子夜江寒9 小时前
MySQL 表创建与数据导入导出
数据库·mysql
菜鸟小九9 小时前
redis基础(安装配置redis)
数据库·redis·缓存
保定公民9 小时前
达梦数据库使用cp备份集恢复报错分析与解决
数据库
中冕—霍格沃兹软件开发测试11 小时前
测试用例库建设与管理方案
数据库·人工智能·科技·开源·测试用例·bug