rename重命名mysql表(MySQL 重命名表的操作方法及注意事项)
rename重命名mysql表
MySQL 重命名表的操作方法及注意事项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 重命名表的资料请关注开心学习网其它相关文章!
- 怎么查看mysql运行日志(通过Query Profiler查看MySQL语句运行时间的操作方法)
- 如何用mysql建立图书管理系统(图书管理系统的sqlserver数据库设计示例)
- mysql性能怎么看(是什么影响了 MySQL 的性能?)
- mysql返回结果集函数(mysql 判断是否为子集的方法步骤)
- mysql5.5.36版本介绍(WDCP控制面板升级mysql为5.7.11的方法)
- mysql的事务隔离级别怎么实现(mysql、oracle默认事务隔离级别的说明)
- mysql 查询都是0的值(MySQL按小时查询数据,没有的补0)
- mysql not exists用法(mysql中EXISTS和IN的使用方法比较)
- mysql数值类型图解(详解mysql持久化统计信息)
- apache搭建php环境(Windows上安装Apache2、PHP5、MySQL5及与Resin配合实现多系统之整合)
- python 数据库实现学生管理系统(python+mysql实现教务管理系统)
- mysql常用存储方案及基本原理(详解分析MySQL8.0的内存消耗)
- mysql自增主键创建过程(深入谈谈MySQL中的自增主键)
- mysql索引原理及调优(mysql高级学习之索引的优劣势及规则使用)
- mysql索引优化有哪些(MySQL如何基于Explain关键字优化索引功能)
- mysql长连接释放和不释放的问题(解决MySQL存储时间出现不一致的问题)
- 阿里最新财报公布 三季度营收增长3 ,将增加150亿美元回购额度 在美股价小涨(阿里最新财报公布)
- 赵薇时胖时瘦 最近变美少女 原因在这里 躺着就变瘦(赵薇时胖时瘦最近变美)
- 学会这26种姿势,你就可以和兵哥哥切磋了(你就可以和兵哥哥切磋了)
- 吴彦祖陈冠希 恩怨 ,失去曾让他流泪的女友,终遇走过18年真爱(吴彦祖陈冠希恩怨)
- 痴情男神 吴彦祖 与妻子恋爱8年,结婚10年,家庭幸福美满(痴情男神吴彦祖)
- 成功破圈,小牛电动SQi强势开 跨(小牛电动SQi强势开)
热门推荐
- sql server导入数据csv文件(大容量csv快速内导入sqlserver的解决方法推荐)
- htaccess伪静态配置(16个简单实用的.htaccess使用技巧)
- svn中tree conflicts错误的解决方法
- php模块使用方法(PHP操作XML中XPath的应用示例)
- vue高阶组件怎么用(vue更多筛选项小组件使用详解)
- python csv文件读取方法(对python读取zip压缩文件里面的csv数据实例详解)
- canvas图片填充位置(手摸手教你用canvas实现给图片添加平铺水印的实现)
- 利用数据库安装centos7(CentOS安装SQL Server vNext CTP1教程)
- html5拖动效果怎么写(Html5 滚动穿透的方法)
- python怎么装opencv(Python基于opencv实现的简单画板功能示例)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9