SQL ALTER TABLE 语句- 灵活修改表结构和数据类型
SQL ALTER TABLE 语句
SQL ALTER TABLE 语句用于在现有表中添加、删除或修改列,也可用于添加和删除各种约束。
ALTER TABLE - 添加列
要在表中添加列,请使用以下语法:
ALTER TABLE 表名
ADD 列名 数据类型;
以下 SQL 向 "Customers" 表添加了一个 "Email" 列:
ALTER TABLE Customers
ADD Email varchar(255);
ALTER TABLE - 删除列
要在表中删除列,请使用以下语法(请注意,某些数据库系统不允许删除列):
ALTER TABLE 表名
DROP COLUMN 列名;
以下 SQL 从 "Customers" 表中删除了 "Email" 列:
ALTER TABLE Customers
DROP COLUMN Email;
ALTER TABLE - 重命名列
要在表中重命名列,请使用以下语法:
ALTER TABLE 表名
RENAME COLUMN 旧名 TO 新名;
ALTER TABLE - 修改数据类型
要更改表中列的数据类型,请使用以下语法:
对于 SQL Server / MS Access:
ALTER TABLE 表名
ALTER COLUMN 列名 数据类型;
对于 MySQL / Oracle(10G 之前的版本):
ALTER TABLE 表名
MODIFY COLUMN 列名 数据类型;
对于 Oracle 10G 及更高版本:
ALTER TABLE 表名
MODIFY 列名 数据类型;
SQL ALTER TABLE 示例
看看 "Persons" 表:
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,将保存日期。
"Persons" 表现在如下所示:
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,将保存以两位或四位格式表示的年份。
删除列示例
接下来,我们想删除 "Persons" 表中名为 "DateOfBirth" 的列。
我们使用以下 SQL 语句:
ALTER TABLE Persons
DROP COLUMN DateOfBirth;
"Persons" 表现在如下所示:
ID LastName FirstName Address City
1 Hansen Ola Timoteivn 10 Sandnes
2 Svendson Tove Borgvn 23 Sandnes
3 Pettersen Kari Storgt 20 Stavanger
希望这些例子能够帮助您更好地理解 SQL ALTER TABLE 语句的用法。
SQL 约束
SQL 约束用于指定表中数据的规则,以确保数据的准确性和可靠性。约束可以在创建表时指定,也可以在创建表后使用 ALTER TABLE 语句添加。
创建表时指定约束
CREATE TABLE 表名 (
列1 数据类型 约束,
列2 数据类型 约束,
列3 数据类型 约束,
....
);
常用的约束类型
1. NOT NULL 约束
确保列不能有 NULL 值。
CREATE TABLE 表名 (
列1 数据类型 NOT NULL,
列2 数据类型,
列3 数据类型,
....
);
2. UNIQUE 约束
确保列中的所有值都是不同的。
CREATE TABLE 表名 (
列1 数据类型 UNIQUE,
列2 数据类型,
列3 数据类型,
....
);
3. PRIMARY KEY 约束
是 NOT NULL 和 UNIQUE 约束的组合,在表中唯一标识每一行。
CREATE TABLE 表名 (
列1 数据类型 PRIMARY KEY,
列2 数据类型,
列3 数据类型,
....
);
4. FOREIGN KEY 约束
用于防止破坏表之间关系的操作。
CREATE TABLE 表名1 (
列1 数据类型 PRIMARY KEY,
列2 数据类型,
列3 数据类型,
....
);
CREATE TABLE 表名2 (
列A 数据类型,
列B 数据类型,
列C 数据类型,
FOREIGN KEY (列A) REFERENCES 表名1(列1)
);
5. CHECK 约束
确保列中的值满足特定条件。
CREATE TABLE 表名 (
列1 数据类型,
列2 数据类型 CHECK (列2 > 0),
列3 数据类型,
....
);
6. DEFAULT 约束
如果未指定值,则为列设置默认值。
CREATE TABLE 表名 (
列1 数据类型,
列2 数据类型 DEFAULT 默认值,
列3 数据类型,
....
);
7. CREATE INDEX 约束
用于快速创建和检索数据库中的数据。
CREATE INDEX 索引名
ON 表名 (列1, 列2, 列3, ...);
这些约束类型可以根据表的设计和需求进行灵活组合使用,以确保数据库中的数据的完整性和一致性。
最后
为了方便其他设备和平台的小伙伴观看往期文章:
微信公众号搜索:Let us Coding,关注后即可获取最新文章推送
看完如果觉得有帮助,欢迎 点赞、收藏、关注
SQL ALTER TABLE 语句- 灵活修改表结构和数据类型的更多相关文章
- SQL-W3School-高级:SQL ALTER TABLE 语句
ylbtech-SQL-W3School-高级:SQL ALTER TABLE 语句 1.返回顶部 1. ALTER TABLE 语句 ALTER TABLE 语句用于在已有的表中添加.修改或删除列. ...
- SQL ALTER TABLE 语句在项目中的使用
1.在实际的项目开发过程中,之前已经创建好的实体类可能需要增加/删除字段,亦或是更改已有字段的属性,比如主键的增长策略从自增型改为UUID型,那么就会涉及到 SQL 中 alter table 语句的 ...
- SQL ALTER TABLE 语句
ALTER TABLE 语句 ALTER TABLE 语句用于在已有的表中添加.修改或删除列. SQL ALTER TABLE 语法 如需在表中添加列,请使用下列语法: ALTER TABLE tab ...
- 为什么在SQL Server2008在视图中修改表结构无效
解决办法: 在SQL server 2008 中,打开菜单-->工具
- mysql ALTER TABLE语句 语法
mysql ALTER TABLE语句 语法 作用:用于在已有的表中添加.修改或删除列.无铁芯直线电机 语法:添加列:ALTER TABLE table_name ADD column_name da ...
- 必须会的SQL语句(二) 创建表、修改表结构、删除表
1.创建数据库表 --使用哪个数据库,如果不写这一句是默认的数据库,也可以用鼠标选当前数据库 use testDB --创建表 Create Table tablename ( ...
- SQL Server -- 回忆笔记(二):增删改查,修改表结构,约束,关键字使用,函数,多表联合查询
SQL Server知识点回忆篇(二):增删改查,修改表结构,约束,关键字使用,函数,多表联合查询 1. insert 如果sql server设置的排序规则不是简体中文,必须在简体中文字符串前加N, ...
- sql server 修改表结构
文章来自http://blog.csdn.net/huwei2003/article/details/6076051 --修改数据库名称.表名称.字段名 --修改数据库名 sp_renamedb 'o ...
- SQL脚本修改表结构
SQL脚本修改表结构 新建表:create table [表名]([自动编号字段] int IDENTITY (1,1) PRIMARY KEY ,[字段1] nVarChar(50) default ...
- SQL Server 修改表结构(转载)
SQL Server 修改表结构 本文链接:https://blog.csdn.net/petezh/article/details/81744374 查看指定表结构 exec sp_help Rep ...
随机推荐
- 使用go module导入本地包
go module是Go1.11版本之后官方推出的版本管理工具,并且从Go1.13版本开始,go module将是Go语言默认的依赖管理工具. 前提 假设我们有learngo和mypackage两个 ...
- 问题:django中对datetime类型数据在pycharm中sqlite3进行修改时,修改后datetime日期数据变成了时间戳类型
这是正在修改的 提交完之后 问题原因 问题原因是sqlite数据库对日期类型不敏感,Pycharm直接插入会变成图中这样的时间戳,用POST请求添加数据或Django自带的后台管理插入不会有这样的问题 ...
- 简单看下最近的Spring Secrurity、Spring漏洞(CVE-2024-22234、CVE-2024-22243)
最近的这两个cve我看国内很多情报将其评为高危,所以想着去看看原理,看完发现都比较简单,利用要求的场景也相对有限(特别是第一个),所以就随便看下就行了 Spring Security 用户认证绕过(C ...
- 【LeetCode贪心#01】分饼干,贪心算法入门(入了但是还没完全入)
分饼干 力扣题目链接(opens new window) 假设你是一位很棒的家长,想要给你的孩子们一些小饼干.但是,每个孩子最多只能给一块饼干. 对每个孩子 i,都有一个胃口值 g[i],这是能让孩子 ...
- 【NLP学习其3.5】词嵌入的特性,为什么词之间会有联系?
词嵌入的特性 现在你有了一堆嵌入向量,我们可以开始学习他们之间的特性了 前情提要:https://www.cnblogs.com/DAYceng/p/14962528.html 先把各向量重新命名便于 ...
- 【Azure 存储服务】Blob中数据通过Stream Analytics导出到SQL/Cosmos DB
问题描述 Json格式的数据目前是存储在Azure Blob中,如何将这些数据Load到Sql DB和CosmosDB中呢? 测试方案 使用Azure流分析服务(Stream Analytics)功能 ...
- 【Flink入门修炼】2-2 Flink State 状态
什么是状态?状态有什么作用? 如果你来设计,对于一个流式服务,如何根据不断输入的数据计算呢? 又如何做故障恢复呢? 一.为什么要管理状态 流计算不像批计算,数据是持续流入的,而不是一个确定的数据集.在 ...
- Codeforces Round 787 (Div. 3)D. Vertical Paths
题目链接 题意:给定一棵树,将这棵树划分成几天互不相交的链,要求最小化链的数量 思路:每个叶子节点一定在一条链中,所以链的数量就是叶子节点的数量,从叶子节点往上跳直到根节点,边跳边标记,路径上所有点都 ...
- Spring与微服务
Spring与微服务 微服务论文 Melvyn Conway 的意识是,像下图所展示的,设计一个系统时,将人员划分为 UI 团队,中间件团队,DBA 团队,那么相应地,软件系统也就会自然地被划分为 U ...
- 光感红外接近传感器AP3426调试总结
一 概念 AP3426是一个高度集成了红外,光感和接近角的传感器.该传感器凭借着高灵敏度广泛应用在可穿戴领域.笔者在一个产品上用了这个传感器.花了一些时间来调试和熟悉这个传感器,这里就做一个总结吧. ...