王妍芳 发表于 2025-6-11 18:39:44

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)特性,目标库下的数据文件是物理文件,而并非软连接
 

来源:程序园用户自行投稿发布,如果侵权,请联系站长删除
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
页: [1]
查看完整版本: MySQL中用rename命令间接实现数据库的重命名