• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    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 语句还是有部分区别的,查询官方文档,主要有几点如下:

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

    总结:

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

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

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

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

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

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

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

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

    以上就是MySQL 重命名表相关知识总结的详细内容,更多关于MySQL 重命名表的资料请关注脚本之家其它相关文章!

    您可能感兴趣的文章:
    • MySQL数据库重命名的快速且安全方法(3种)
    • mysql事件之修改事件(ALTER EVENT)、禁用事件(DISABLE)、启用事件(ENABLE)、事件重命名及数据库事件迁移操作详解
    • 详解MYSQL中重命名procedure的一种方法
    • MySQL中使用SQL语句对字段进行重命名
    • mysql数据库重命名语句分享
    • 教你怎么用Python操作MySql数据库
    • 用python开发一款操作MySQL的小工具
    • Python基础之操作MySQL数据库
    • Python聊天室带界面实现的示例代码(tkinter,Mysql,Treading,socket)
    • Python操作MySQL数据库的简单步骤分享
    • Python使用sql语句对mysql数据库多条件模糊查询的思路详解
    • Python中tkinter+MySQL实现增删改查
    • 运用Python快速的对MySQL数据库进行重命名
    上一篇:Mysql官方性能测试工具mysqlslap的使用简介
    下一篇:Oracle更换为MySQL遇到的问题及解决
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    MySQL 重命名表的操作方法及注意事项 MySQL,重命,名表,的,操作,