重命名表,应该怎么做

北京治疗荨麻疹医院 http://pf.39.net/bdfyy/bdfhl/210708/9159711.html

前言:

有时候我们会遇到重命名表的需求,比如说因业务变化,需要将表a重命名为表b。这个时候可以执行RENAMETABLE语句或ALTERTABLE语句来重命名表。本篇文章我们一起来学习下重命名表相关知识。

1.重命名表方法

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

#RENAMETABLE语法:RENAMETABLEtbl_nameTOnew_tbl_name[,tbl_name2TOnew_tbl_name2]...#ALTERTABLE语法:ALTERTABLEold_tableRENAMEnew_table;#具体示例:mysqlshowtables;+------------------+

Tables_in_testdb

+------------------+

tb1

tb2

+------------------+2rowsinset(0.00sec)mysqlrenametabletb1tonew_tb1;QueryOK,0rowsaffected(0.03sec)mysqlaltertabletb2renamenew_tb2;QueryOK,0rowsaffected(0.04sec)mysqlshowtables;+------------------+

Tables_in_testdb

+------------------+

new_tb1

new_tb2

+------------------+2rowsinset(0.00sec)

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

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

RENAMETABLEold_table1TOnew_table1,old_table2TOnew_table2,old_table3TOnew_table3;

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

RENAMETABLEold_tableTOtmp_table,new_tableTOold_table,tmp_tableTOnew_table;

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

RENAMETABLEcurrent_db.tbl_nameTOother_db.tbl_name;ALTERTABLEcurrent_db.tbl_namerenameother_db.tbl_name;#拼接SQL实现将某个数据库中的表全部转移至另一个数据库中SELECTCONCAT(renametableold_db.,TABLE_NAME,tonew_db.,TABLE_NAME,;)FROMinformation_schema.TABLESWHERETABLE_SCHEMA=old_db;

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

2.注意事项

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

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

RENAMETABLE适用于视图,但不能将视图重命名转移到其他数据库中,ALTERTABLE不能重命名视图。

ALTERTABLE可以重命名临时表(TEMPORARYTABLE),RENAMETABLE不可以。

RENAMETABLE可以在单个语句中重命名多个表,ALTERTABLE只能重命名一个。

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

总结:

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

RENAMETABLE语句和ALTERTABLE语句都可以对表进行重命名,二者稍有区别,更推荐用RENAMETABLE语句。

重命名操作需要获取元数据锁,执行前要确保无活跃事务占用。

通过重命名表,可以将一个表从一个数据库转移到另一个数据库中,间接实现重命名数据库。

实际生产场景,重命名表要慎重考虑,特别是存在视图及函数依赖的。

重命名操作执行完成后,要检查用户权限及相关依赖问题,及时将依赖关系中的表名改为新的表名。

若表中存在触发器或外键等约束,重命名时要格外注意。

重命名操作一般在秒级完成,若执行时间过长,请检查链接状态。

推荐阅读

(点击标题可跳转阅读)

MySQL慢日志全解析!

MySQL数据迁移那些事儿

MySQL角色(role)功能介绍

-End-动动手指转发、在看是对我最大的鼓励预览时标签不可点收录于话题#个上一篇下一篇

转载请注明:http://www.sonphie.com/jbzl/14392.html

  • 上一篇文章:
  • 下一篇文章:
  • 网站简介| 发布优势| 服务条款| 隐私保护| 广告合作| 网站地图| 版权申明

    当前时间: