前言:

有时候咱们会遇到重命名表的需要,比如说因业务变动,须要将表 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 语句。
  • 重命名操作须要获取元数据锁,执行前要确保无沉闷事务占用。
  • 通过重命名表,能够将一个表从一个数据库转移到另一个数据库中,间接实现重命名数据库。
  • 理论生产场景,重命名表要慎重考虑,特地是存在视图及函数依赖的。
  • 重命名操作执行实现后,要检查用户权限及相干依赖问题,及时将依赖关系中的表名改为新的表名。
  • 若表中存在触发器或外键等束缚,重命名时要分外留神。
  • 重命名操作个别在秒级实现,若执行工夫过长,请查看链接状态。