【重学 MySQL】四十七、表的操作技巧——修改、重命名、删除与清空

news2024/11/17 1:49:44

【重学 MySQL】四十七、表的操作技巧——修改、重命名、删除与清空

  • 修改表
    • 添加字段
      • 语法
      • 示例
      • 注意事项
    • 删除字段
      • 语法
      • 示例
    • 修改字段
      • 使用 MODIFY COLUMN
        • 语法
        • 示例
      • 使用 CHANGE COLUMN
        • 语法
        • 示例
  • 重命名表
    • 语法
    • 示例
  • 删除表
      • 语法
      • 示例
  • 清空表
    • 使用 `TRUNCATE TABLE`
    • 使用 `DELETE FROM`
    • 对比 `TRUNCATE TABLE` 和 `DELETE FROM`
      • 操作方式
      • 性能
      • 事务处理
      • 触发器和外键约束
      • 自增主键
      • 使用建议
  • 注意事项
  • 总结

在这里插入图片描述

修改表

在MySQL中,我们经常需要对已存在的表进行修改,以满足不断变化的数据存储需求。这通常包括添加新列、删除现有列、修改列的数据类型或约束条件等操作。

添加字段

在MySQL中,为已存在的表添加字段(也称为列)是一个常见的操作,这通常是为了满足新的数据存储需求或适应业务逻辑的变化。使用ALTER TABLE语句可以方便地实现这一操作。

语法

ALTER TABLE table_name ADD COLUMN column_name datatype [constraints] [FIRST | AFTER existing_column];
  • table_name:要添加字段的表的名称。
  • column_name:新字段的名称。
  • datatype:新字段的数据类型,如INTVARCHARDATE等。
  • constraints:对新字段的约束条件,如NOT NULLDEFAULT值、UNIQUE等(可选)。
  • [FIRST | AFTER existing_column]
    • FIRST:将新字段添加到表的开头。
    • AFTER existing_column:将新字段添加到指定字段 existing_column 之后。如果省略此部分,新字段将默认添加到表的末尾。

示例

  1. 将新字段添加到表末尾(默认行为):

    ALTER TABLE employees  
    ADD COLUMN phone_number VARCHAR(20);
    
  2. 将新字段添加到表开头:

    ALTER TABLE employees  
    ADD COLUMN employee_id INT AUTO_INCREMENT FIRST,  
    ADD PRIMARY KEY (employee_id); -- 假设这是主键字段
    

    注意:在添加主键字段时,通常也会同时设置 AUTO_INCREMENT 属性和 PRIMARY KEY 约束。

  3. 将新字段添加到特定字段之后:

    ALTER TABLE employees  
    ADD COLUMN hire_date DATE AFTER last_name;
    

    在这个例子中,hire_date 字段将被添加到 last_name 字段之后。

注意事项

  1. 字段位置:在MySQL中,默认情况下新添加的字段会被放置在表的最后。如果需要将新字段添加到特定位置,可以使用AFTER column_name子句来指定位置。例如,将phone_number字段添加到email字段之后:

    ALTER TABLE employees ADD COLUMN phone_number VARCHAR(20) AFTER email;
    

    或者,如果希望将新字段添加到表的最前面,可以使用FIRST关键字:

    ALTER TABLE employees ADD COLUMN phone_number VARCHAR(20) FIRST;
    
  2. 表锁定:在执行ALTER TABLE操作时,MySQL可能会锁定表,这会导致在该表上的其他操作(如查询、更新等)被阻塞,直到ALTER TABLE操作完成。因此,在执行此类操作时应尽量选择在系统负载较低的时候进行。

  3. 备份数据:虽然ALTER TABLE操作通常是安全的,但在执行任何可能影响表结构的操作之前,始终建议备份数据以防止意外情况发生。

  4. 权限要求:执行ALTER TABLE操作需要相应的权限。通常,只有表的创建者或具有足够权限的用户才能修改表结构。

通过掌握ALTER TABLE ... ADD COLUMN语句的使用,我们可以灵活地根据需求为MySQL数据库中的表添加新的字段。

删除字段

在MySQL中,删除表中的字段(也称为列)是一个需要谨慎操作的任务,因为一旦字段被删除,与该字段相关的所有数据也将被永久移除,且无法恢复(除非你有备份)。使用ALTER TABLE语句可以方便地删除表中的字段。

语法

ALTER TABLE table_name DROP COLUMN column_name;
  • table_name:要删除字段的表的名称。
  • column_name:要删除的字段的名称。

示例

假设我们有一个名为employees的表,并且该表包含一个名为middle_name的字段,现在我们想要删除这个字段,可以使用以下SQL语句:

ALTER TABLE employees DROP COLUMN middle_name;

执行上述语句后,middle_name字段及其所有数据将从employees表中被永久删除。

修改字段

在MySQL中,修改表中的字段(也称为列)通常涉及更改字段的数据类型、名称、默认值、约束条件等。这可以通过ALTER TABLE语句结合MODIFY COLUMNCHANGE COLUMN子句来实现。

使用 MODIFY COLUMN

MODIFY COLUMN 用于更改现有字段的数据类型、约束条件等,但不能更改字段的名称。

语法
ALTER TABLE table_name MODIFY COLUMN column_name datatype [constraints];
  • table_name:要修改的表的名称。
  • column_name:要修改的字段的名称。
  • datatype:新的数据类型。
  • [constraints]:可选的字段约束条件,如 NOT NULLDEFAULT 值、UNIQUE 键等。
示例

假设我们有一个名为employees的表,并且该表包含一个名为salary的字段,现在我们想要更改该字段的数据类型为DECIMAL并设置默认值为50000.00,可以使用以下SQL语句:

ALTER TABLE employees MODIFY COLUMN salary DECIMAL(10, 2) DEFAULT 50000.00;

使用 CHANGE COLUMN

CHANGE COLUMN 既可以更改字段的数据类型、约束条件,也可以更改字段的名称。

语法
ALTER TABLE table_name CHANGE COLUMN old_column_name new_column_name datatype [constraints];
  • table_name:要修改的表的名称。
  • old_column_name:要修改的现有字段的名称。
  • new_column_name:新的字段名称(如果不需要更改名称,可以与old_column_name相同)。
  • datatype:新的数据类型。
  • [constraints]:可选的字段约束条件。
示例

假设我们有一个名为employees的表,并且该表包含一个名为emp_salary的字段,现在我们想要将字段名称更改为salary,并将其数据类型更改为DECIMAL,同时设置默认值为50000.00,可以使用以下SQL语句:

ALTER TABLE employees CHANGE COLUMN emp_salary salary DECIMAL(10, 2) DEFAULT 50000.00;

重命名表

在MySQL中,重命名表的操作相对简单,你可以使用RENAME TABLE语句来实现。这个语句允许你一次性重命名一个或多个表。

语法

RENAME TABLE old_table_name TO new_table_name;

或者,如果你需要同时重命名多个表,可以使用逗号分隔的列表(注意,在MySQL 8.0及更高版本中,一次性重命名多个表的能力被限制为在同一个数据库内的表):

RENAME TABLE 
    old_table_name1 TO new_table_name1,
    old_table_name2 TO new_table_name2,
    ...;
  • old_table_name:当前的表名称。
  • new_table_name:新的表名称。

示例

假设你有一个名为employees的表,现在你想要将这个表重命名为staff,你可以使用以下SQL语句:

RENAME TABLE employees TO staff;

如果你同时想要将另一个名为departments的表重命名为orgs,你可以这样做:

RENAME TABLE 
    employees TO staff,
    departments TO orgs;

删除表

在MySQL中,删除表的操作是通过DROP TABLE语句来实现的。这个操作是永久性的,一旦执行,表及其包含的所有数据都会被删除,且无法撤销。因此,在执行此操作之前,请务必确保你已经备份了所有需要的数据,或者确认这些数据不再需要。

语法

DROP TABLE IF EXISTS table_name;
  • table_name:要删除的表的名称。

示例

假设你有一个名为old_table的表,现在你想要删除它,可以使用以下SQL语句:

DROP TABLE IF EXISTS old_table;

注意DROP TABLE操作是不可逆的,一旦执行,表及其所有数据都将被永久删除,因此在执行此操作前务必备份重要数据。

通过正确地使用DROP TABLE语句,你可以安全地删除MySQL数据库中的表。但请务必谨慎操作,并在执行前做好充分的准备和评估。如果你不确定是否应该删除某个表,或者担心删除操作可能会带来不可预知的后果,建议先咨询数据库管理员或具有相关经验的同事。

清空表

在MySQL中,如果你想要清空表中的所有数据,但保留表结构(即表的定义、索引、约束等),你可以使用TRUNCATE TABLE语句或DELETE FROM语句。这两种方法各有优缺点,适用于不同的场景。

使用 TRUNCATE TABLE

TRUNCATE TABLE 是一种快速清空表的方法,它通常比 DELETE FROM 更高效,因为它不会逐行删除数据,而是直接释放表数据所占用的空间并重置表。但是,TRUNCATE TABLE 是一个DDL(数据定义语言)操作,而不是DML(数据操作语言)操作,这意味着它会自动提交,不能回滚,并且会重置表的自增计数器。

TRUNCATE TABLE table_name;
  • table_name:要清空的表的名称。

注意事项

  • TRUNCATE TABLE 不能带有 WHERE 子句,它会删除表中的所有行。
  • 如果表中有外键约束,并且这些外键被其他表引用,则可能无法直接 TRUNCATE 该表。
  • TRUNCATE TABLE 会重置表的自增计数器(AUTO_INCREMENT)。
  • TRUNCATE TABLE 通常比 DELETE 快,因为它不生成单独的行删除操作。

使用 DELETE FROM

DELETE FROM 语句逐行删除表中的数据,并且可以在 WHERE 子句中指定条件来删除特定的行。由于 DELETE 是DML操作,它可以被事务控制,允许回滚。

DELETE FROM table_name [WHERE condition];
  • table_name:要清空的表的名称。
  • [WHERE condition]:可选的条件,用于指定要删除的行。如果不带条件,则会删除表中的所有行。

注意事项

  • DELETE FROM 可以带有 WHERE 子句来指定删除条件。
  • DELETE FROM 操作可以被事务包围,允许回滚。
  • DELETE FROM 通常比 TRUNCATE TABLE 慢,特别是当表中有大量数据时。
  • DELETE FROM 不会重置表的自增计数器,除非使用 TRUNCATE TABLE 或手动重置。

对比 TRUNCATE TABLEDELETE FROM

TRUNCATE TABLEDELETE FROM是MySQL中用于删除表中数据的两种不同方法,它们之间存在显著的差异。

操作方式

  • TRUNCATE TABLE:这是一个DDL(数据定义语言)操作,它直接删除表中的所有数据,并重置表的自增计数器(如果存在)。该操作相当于删除表并重新创建一个空表,但不会删除表结构(如列、索引、约束等)。
  • DELETE FROM:这是一个DML(数据操作语言)操作,它逐行删除表中的数据。可以通过WHERE子句指定删除条件,如果没有条件则删除所有行。此外,DELETE操作会触发相关的触发器和外键约束。

性能

  • TRUNCATE TABLE:由于TRUNCATE操作不会逐行删除数据,而是直接释放整个表的存储空间,因此通常比DELETE操作更快,特别是在处理大型表时。
  • DELETE FROMDELETE操作需要逐行删除数据,并记录每个删除操作的事务日志,以便支持回滚。因此,在处理大量数据时,DELETE操作可能会比较慢,并且会占用更多的磁盘空间来存储事务日志。

事务处理

  • TRUNCATE TABLETRUNCATE操作是一个隐式的提交操作,它会立即提交当前事务并释放锁。因此,它不能在事务中回滚。
  • DELETE FROMDELETE操作可以在事务中使用,并且支持回滚。如果在事务中执行DELETE操作后发生错误或需要取消删除,可以使用ROLLBACK命令来撤销该操作。

触发器和外键约束

  • TRUNCATE TABLETRUNCATE操作不会触发与表相关的触发器,也不会检查外键约束。因此,如果表被其他表的外键所引用,则可能无法直接TRUNCATE该表。
  • DELETE FROMDELETE操作会触发与表相关的触发器,并且会检查外键约束。如果尝试删除的行被其他表的外键所引用,则DELETE操作会失败并返回错误。

自增主键

  • TRUNCATE TABLE:执行TRUNCATE操作后,表的自增主键计数器会被重置。这意味着下一次插入数据时,自增主键将从初始值(通常是1)开始。
  • DELETE FROMDELETE操作不会重置表的自增主键计数器。即使删除了所有行,自增主键的计数器也会继续递增。

使用建议

  • 如果需要快速清空表中的所有数据,并且不关心自增主键计数器的重置、触发器的触发或外键约束的检查,可以使用TRUNCATE TABLE
  • 如果需要在事务中控制数据的删除,或者需要基于特定条件删除行,或者希望保留自增主键计数器的当前值,则应该使用DELETE FROM

综上所述,TRUNCATE TABLEDELETE FROM在MySQL中各有优缺点,选择哪种方法取决于具体的需求和场景。在使用这些命令时,请务必谨慎操作,并确保已经备份了重要的数据。

在执行任何清空表的操作之前,请务必备份数据,以防万一需要恢复。

注意事项

  1. 权限要求:执行RENAME TABLE操作需要相应的权限。通常,只有表的创建者或具有足够权限的用户才能重命名表。

  2. 表锁定:在执行RENAME TABLE操作时,MySQL会锁定涉及的表以进行结构修改。这可能会导致在该表(或这些表)上的其他操作被阻塞,直到RENAME TABLE操作完成。因此,建议在系统负载较低且对表的使用较少的时候进行此类操作。

  3. 依赖关系:检查要重命名的表是否被其他表的查询、视图、存储过程、触发器等引用,或者是否作为外键的参照表。如果有,你需要先处理这些依赖关系,否则可能会导致数据库完整性问题或查询错误。

  4. 应用程序更新:如果你的应用程序直接引用了要重命名的表,你需要确保更新应用程序中的相关代码,以使用新的表名称。

  5. 数据库引擎:虽然大多数MySQL存储引擎都支持RENAME TABLE操作,但某些特定的引擎(如Federated、Archive等)可能有特殊的限制或要求。在使用这些引擎时,请查阅相关的文档。

  6. 复制和分区:如果你的MySQL服务器配置了复制或使用了分区表,重命名表时可能需要额外的注意。例如,在复制环境中,你需要确保所有相关的从服务器都应用了相应的更改。

通过正确地使用RENAME TABLE语句,你可以安全地重命名MySQL数据库中的表。但请务必谨慎操作,并在执行前做好充分的准备和评估。

总结

通过掌握上述操作技巧,我们可以更加灵活和高效地管理MySQL数据库中的表。无论是修改表结构、重命名表、删除表还是清空表,都可以根据实际需求选择合适的操作方式。同时,务必注意在执行删除或清空操作前备份重要数据,以防止数据丢失。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2184775.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

聊聊晶圆厂中的常见口语(1)

知识星球里的学员问:半导体公司的工程师总爱用一些英语代替中文,比如care,show,用这种简单的单词代替中文,能不能给我们总结工程师常用的英语单词,比较口语化的! 为什么晶圆厂会用很多英文口语&#xff1f…

华为---以太网静态路由配置使用下一跳通信正常,而使用出接口无法通信

目录 1. 实验环境 2. 结果测试 3. 分析验证 3.1 以太网静态路由配置使用下一跳跨网段通信抓包分析 3.2 以太网静态路由配置使用出接口跨网段通信抓包分析 3.3 以太网静态路由配置使用出接口无法跨网段通信问题解决办法 1. 实验环境 以太网静态路由配置使用下一跳跨网段通…

番茄成熟度检测系统源码分享

番茄成熟度检测检测系统源码分享 [一条龙教学YOLOV8标注好的数据集一键训练_70全套改进创新点发刊_Web前端展示] 1.研究背景与意义 项目参考AAAI Association for the Advancement of Artificial Intelligence 项目来源AACV Association for the Advancement of Computer V…

Opencv第十一章——视频处理

1. 读取并显示摄像头视频 1.1 VideoCapture类 VideoCapture类提供了构造方法VideoCapture(),用于完成摄像头的初始化工作,其语法格式如下: capture cv2.VideoCapture(index) 参数说明: capture:要打开的摄像头视频。 index:摄像头设备索引。…

【区间dp】AT_dp_l 题解

题意 给一个双端队列,双方轮流取数,每一次能且只能从队头或队尾取数,取完数后将这个数从队列中弹出。双方都希望自己取的所有数之和尽量大,且双方都以最优策略行动,假设先手取的所有数之和为 X X X,后手取…

【Git】一文看懂Git

Git 一、简介1. Git 与 SVN 区别1.1 Git 是分布式的,SVN 不是1.1.1 分布式版本控制系统Git1.1.2 集中式版本控制系统SVN 1.2 Git 把内容按元数据方式存储,而 SVN 是按文件1.3 Git 分支和 SVN 的分支不同1.4 Git 没有一个全局的版本号,而 SVN …

五.运输层

目录 5.1概述 5.2传输层的寻址与端口 熟知端口号 套接字(Socket) 5.3 UDP 特点 UDP报文格式 UDP校验 二进制反码求和 5.4 TCP 特点 可靠传输 停止等待协议 流水线方式 累计应答 流量控制 滑动窗口 拥塞控制 三次握手,四次握手 5.1概述 只有主机…

Pikachu-Cross-Site Scripting-反射型xss(get)

存储型XSS 存储型XSS是指恶意脚本被存储在目标服务器上,当用户访问包含该脚本的页面时,脚本会被执行。攻击者通常通过输入框、留言板等用户可输入的地方进行注入。例如,攻击者可以在留言板中输入恶意脚本,当其他用户查看留言时&a…

3.基于分数的生成模型

1.简介 基于分数的生成模型(SGM)的核心是Stein分数(或分数函数)。给定一个概率密度函数p(x),其分数函数定义为对数概率密度的梯度Vxlogp(x)。生成模型通过学习并建模输入数据的分布,从而采集生成新的样木,该模型广泛运用于图片视频生成、文本…

假期惊喜,收到公司款项86167.14元

假期惊喜 近日,有网友爆料称,比亚迪在未提前通知员工的情况下,突然发放了利润奖金。 有人获得了七八万元,也有人拿到了十多万元。 一位比亚迪员工的帖子显示,在9月26日下午,他的银行卡突然收到一笔 86167.1…

数字化那点事:一文读懂数字孪生

一、数字孪生的定义 数字孪生(Digital Twin)是指通过数字技术构建的物理实体的虚拟模型,能够对该实体进行全方位、动态跟踪和仿真预测。简单来说,数字孪生就是在一个设备或系统的基础上创造一个数字版的“克隆体”,这…

Redis --- 第二讲 --- 特性和安装

一、背景知识 Redis特性: Redis是一个在内存中存储数据的中间件,用于作为数据库,作为缓存,在分布式系统中能够大展拳脚。Redis的一些特性造就了现在的Redis。 在内存中存储数据,通过一系列的数据结构。MySQL主要是通…

Ollama安装部署CodeGeeX4 - ALL - 9B

一、模型本地部署准备 1、 conda create -n ollama python3.82、 curl -fsSL https://ollama.com/install.sh | sh3、验证安装 安装完成后,通过运行以下命令来验证Ollama是否正确安装: ollama --version4、启动ollama ollama serve模型地址&#xff…

【重学 MySQL】四十八、DCL 中的 commit 和 rollback

【重学 MySQL】四十八、DCL 中的 commit 和 rollback commit的定义与作用rollback的定义与作用使用场景相关示例注意事项DDL 和 DML 的说明 在MySQL中,DCL(Data Control Language,数据控制语言)用于管理数据库用户和控制数据的访问…

Ubuntu 安装RUST

官方给的是这样如下脚本 curl --proto https --tlsv1.2 -sSf https://sh.rustup.rs | sh 太慢了 curl --proto https --tlsv1.2 -sSf https://sh.rustup.rs | sh -x 执行这个脚本后会给出对应的下载链接 如下图 我直接给出来 大多数应该都是这个 https://static.rust-…

初识算法 · 双指针(1)

目录 前言: 双指针算法 题目一: ​编辑 题目二: 前言: 本文作为算法部分的第一篇文章,自然是少不了简单叭叭两句,对于算法部分,多刷是少不了,我们刷题从暴力过度到算法解法,自…

csp-j模拟二补题报告

目录传送门 前言第一题下棋(chess)我的代码(AC了)AC代码 第二题汪洋(BigWater)我的代码(0)AC代码 第三题删数(delnum)我的代码(0)AC代…

秋招突击——9/13——携程提前准备和实际面经——专程飞过去线下,结果一面挂(难受)

文章目录 引言面经收集面经整理一1. ArrayList和LinkedList2. 线程安全的列表和链表有么?如果没有怎么实现?3. threadlocal4. synchronized锁升级过程及原理5. ReentrantLock原理,以及和synchronized的对比6. 线程池工作原理7. redis常用数据…

数据流和数据流处理技术

一数据流 首先明确数据流概念:数据流是连续不断生成的、快速变化的无界数据序列 数据流类型: 数据流大致可以分为四种类型 1.连续型数据流:不断地产生数据,数据稳定速度输入系统。 2.突发型数据流:在某特定时间或…

【吊打面试官系列-MySQL面试题】Mysql如何存储日期?

大家好,我是锋哥。今天分享关于【Mysql如何存储日期?】面试题,希望对大家有帮助; Mysql如何存储日期? 1000道 互联网大厂Java工程师 精选面试题-Java资源分享网 Datatime:以 YYYY-MM-DD HH:MM:SS 格式存储时期时间&a…