1.重命名表方法

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

# RENAME TABLE 语法:RENAMETABLEtbl_nameTOnew_tbl_name[,tbl_name2TOnew_tbl_name2]...# ALTER TABLE 语法:ALTERTABLEold_tableRENAMEnew_table;#具体示例:mysql>showtables;+------------------+|Tables_in_testdb|+------------------+|tb1||tb2|+------------------+2rowsinset(0.00sec)mysql>renametabletb1tonew_tb1;QueryOK,0rowsaffected(0.03sec)mysql>altertabletb2renamenew_tb2;QueryOK,0rowsaffected(0.04sec)mysql>showtables;+------------------+|Tables_in_testdb|+------------------+|new_tb1||new_tb2|+------------------+2rowsinset(0.00sec)

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

RENAMETABLEold_table1TOnew_table1,old_table2TOnew_table2,old_table3TOnew_table3;
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';

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 语句。

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

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

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

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

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

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

更多相关文章

  1. Android安装卸载程序具体操作方法解析
  2. Android(安卓)studio 打包apk如何重命名apk名称
  3. Android安装卸载程序具体操作方法解析
  4. Android文件系统的结构及目录用途、操作方法 整理
  5. android 中Drawable跟Bitmap转换及常用于图片相关操作方法 - And
  6. Android安装卸载程序具体操作方法解析
  7. Android安装卸载程序具体操作方法解析
  8. Python将CSV文件转化为HTML文件的操作方法
  9. RAID5常见故障介绍及raid5故障后常规操作方法

随机推荐

  1. android 向webview传值
  2. Android Studio 的原生输入框控件 EditTe
  3. 学习Android从0开始之背景篇-Android系统
  4. 【百度网盘】老罗android开发视频教程[压
  5. Android SDK安装时出错“android Failed
  6. android源码学习之animation1
  7. EditText使用属性详解
  8. Android相对布局RelativeLayout各属性介
  9. .Net 转战 Android 4.4 日常笔记目录
  10. Android:控件样式触发