重命名表,应该怎么做?

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 有时候我们会遇到重命名表的需求,比如说因业务变化,需要将表 a 重命名为表 b 。这个时候可以执行 RENAME TABLE 语句或 ALTER TABLE 语句来重命名表。本篇文章我们一起来学习下重命名表相关知识。

1.重命名表方法


使用 RENAME TABLE 语句或 ALTER TABLE 语句都可以对表进行重命名,基本语法如下:

# RENAME TABLE 语法:
RENAME TABLE
    tbl_name TO new_tbl_name
    [, tbl_name2 TO new_tbl_name2] ...
# ALTER TABLE 语法:
ALTER TABLE old_table RENAME new_table;
# 具体示例:
mysql> show tables;
+------------------+
| Tables_in_testdb |
+------------------+
| tb1              |
| tb2              |
+------------------+
2 rows in set (0.00 sec)
mysql> rename table tb1 to new_tb1;
Query OK, 0 rows affected (0.03 sec)
mysql> alter table tb2 rename new_tb2;
Query OK, 0 rows affected (0.04 sec)
mysql> show tables;
+------------------+
| Tables_in_testdb |
+------------------+
| new_tb1          |
| new_tb2          |
+------------------+
2 rows in set (0.00 sec)

显然易见,在执行重命名表时,旧表(old_table_name)必须存在,而新表(new_table_name)一定不存在。如果新表  new_table_name 确实存在,该语句将失败。


执行重命名表的用户必须具有原始 table 的 ALTER 和 DROP 权限,以及新 table 的 CREATE 和 INSERT 权限。与 ALTER TABLE 不同,RENAME TABLE 可以在单个语句中重命名多个表:

RENAME TABLE old_table1 TO new_table1,
             old_table2 TO new_table2,
             old_table3 TO new_table3;

若一次性重命名多个表,则重命名操作从左到右执行。因此,要交换两个表名,可以执行此操作(假设中间表名称为tmp_table且不存在):

RENAME TABLE old_table TO tmp_table,
             new_table TO old_table,
             tmp_table TO new_table;

通过重命名表,我们还可以将一个表从一个数据库移动到另一个数据库中,语法如下:

RENAME TABLE current_db.tbl_name TO other_db.tbl_name;
ALTER TABLE current_db.tbl_name rename other_db.tbl_name;
# 拼接SQL 实现将某个数据库中的表全部转移至另一个数据库中
SELECT
    CONCAT( 'rename table old_db.', TABLE_NAME, ' to new_db.', TABLE_NAME, ';' ) 
FROM
    information_schema.TABLES 
WHERE
    TABLE_SCHEMA = 'old_db';

事实上,MySQL 并没有提供重命名数据库的操作,我们可以通过将某个库的所有表都通过重命名转移的另一个库中,来间接实现重命名库,只是原库仍然存在。


2.注意事项


值得注意的是,重命名操作是原子完成的,需要获取该表的元数据锁,因此我们在执行 RENAME TABLE 前,要确保该表没有活跃的事务且没有被锁定。因为只需更改元数据,所以对于大表重命名也是很迅速的。此外,如果该表具有触发器,则无法将该表通过重命名方式转移到另外一个库中。


其实,RENAME TABLE 语句和 ALTER TABLE 语句还是有部分区别的,查询官方文档,主要有几点如下:


  • RENAME TABLE 适用于视图,但不能将视图重命名转移到其他数据库中,ALTER TABLE 不能重命名视图。
  • ALTER TABLE 可以重命名临时表(TEMPORARY TABLE),RENAME TABLE 不可以。
  • RENAME TABLE 可以在单个语句中重命名多个表,ALTER TABLE 只能重命名一个。


虽然重命名操作快捷迅速,但实际生产场景中,对于表的重命名还是要慎重考虑,也许你的重命名操作没问题,但后续对象之间的依赖调用可能出现问题。比如你将一个表 tb1 重命名为 new_tb1,若有视图及函数依赖 tb1 ,并且你没及时修改这些视图及函数的话,那么再次调用这些视图和函数就可能报错 tb1 不存在,因为在这些视图及函数的定义中,仍用的是 tb1 的名称。此外重命名表或视图后,要注意用户权限问题,如果有显式指定某个用户对该表的权限,则需要重新赋予对新表的权限。若表中存在外键等约束时,执行重命名操作也要格外小心,做好检查。


总结:


本篇文章主要介绍了重命名表的操作方法及注意事项,将本文的重点总结如下:


  • RENAME TABLE 语句和 ALTER TABLE 语句都可以对表进行重命名,二者稍有区别,更推荐用 RENAME TABLE 语句。
  • 重命名操作需要获取元数据锁,执行前要确保无活跃事务占用。
  • 通过重命名表,可以将一个表从一个数据库转移到另一个数据库中,间接实现重命名数据库。
  • 实际生产场景,重命名表要慎重考虑,特别是存在视图及函数依赖的。
  • 重命名操作执行完成后,要检查用户权限及相关依赖问题,及时将依赖关系中的表名改为新的表名。
  • 若表中存在触发器或外键等约束,重命名时要格外注意。
  • 重命名操作一般在秒级完成,若执行时间过长,请检查链接状态。
相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
分页列表数据不出来,初始化页面数据不出来的原因,Create中传一个参数1,解决bug的方法,学习敲代码的时候仔细与原项目比对,从上比到下
分页列表数据不出来,初始化页面数据不出来的原因,Create中传一个参数1,解决bug的方法,学习敲代码的时候仔细与原项目比对,从上比到下
|
6月前
|
SQL 前端开发 关系型数据库
MYSQL基础知识之【复制表】
MYSQL基础知识之【复制表】
80 1
|
SQL 关系型数据库 MySQL
(PD)PowerDesigner如何将一个包里的表拷贝到另一个表以后在视图中也可以显示?
(PD)PowerDesigner如何将一个包里的表拷贝到另一个表以后在视图中也可以显示?
177 0
|
SQL 关系型数据库 MySQL
MySQL基础-表操作~修改数据
修改数据的具体语法为: UPDATE 表名 SET 字段名1 = 值1 , 字段名2 = 值2 , .... [ WHERE 条件 ] ;
146 0
|
数据库 索引
存在逻辑删除的表字段上建立唯一索引的巧办法 (逻辑删除与唯一索引)
设计数据库唯一索引时,经常会碰到唯一删除的键值,导致很难处理,这里就简单介绍一种巧办法,帮你快速解决该问题
1984 0
存在逻辑删除的表字段上建立唯一索引的巧办法 (逻辑删除与唯一索引)
|
数据库
LeetCode(数据库)- 修复表中的名字
LeetCode(数据库)- 修复表中的名字
106 0
|
存储 关系型数据库 MySQL
MySQL索引的创建,查看,删除,修改操作详解(上)
MySQL索引的创建,查看,删除,修改操作详解
145 0
|
SQL 关系型数据库 MySQL
MySQL索引的创建,查看,删除,修改操作详解(下)
MySQL索引的创建,查看,删除,修改操作详解
227 0