实际上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)特性,目标库下的数据文件是物理文件,而并非软连接
来源链接:https://www.cnblogs.com/wy123/p/18884262
© 版权声明
本站所有资源来自于网络,仅供学习与参考,请勿用于商业用途,否则产生的一切后果将由您(转载者)自己承担!
如有侵犯您的版权,请及时联系3500663466#qq.com(#换@),我们将第一时间删除本站数据。
如有侵犯您的版权,请及时联系3500663466#qq.com(#换@),我们将第一时间删除本站数据。
THE END
暂无评论内容