MySQL中用rename命令间接实现数据库的重命名

实际上MySQL不支持重命名数据库(修改数据库的文件路径名不行),所以只能间接实现,这里使用rename的方式,将表从一个库“转移”到另一个库。如下代码可以将db01库下面的表“转移”到db02下。

SELECT CONCAT('rename table db01.',table_name,' to db02.',TABLE_NAME,';') AS rename_table
FROM information_schema.`TABLES` WHERE table_schema = 'db01';
--output
rename table db01.t2 to db02.t2;
rename table db01.test_table to db02.test_table;
rename table db01.TestTable01 to db02.TestTable01;

 

1,rename table的时候会将表结构以及数据文件本身用到目标库下,并且从源库中删掉,相当于Windows下文件的“剪切”操作,所以是间接重命名
2,rename的执行过程是一个瞬时操作,不管表有多大,1MB的表与100GB的表一样,都是瞬时完成的,利用了文件系统的硬链接(hard link)特性,目标库下的数据文件是物理文件,而并非软连接

 

作者:MSSQL123原文地址:https://www.cnblogs.com/wy123/p/18884262

%s 个评论

要回复文章请先登录注册