查看: 64|回覆: 0

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

[複製鏈接]

3

主題

0

回帖

0

積分

热心网友

金币
0
閲讀權限
220
精華
0
威望
0
贡献
0
在線時間
0 小時
註冊時間
2009-6-20
發表於 2025-5-19 15:04:00 | 顯示全部樓層 |閲讀模式

实际上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
回覆

使用道具 舉報

您需要登錄後才可以回帖 登錄 | 立即注册

本版積分規則

相关侵权、举报、投诉及建议等,请发 E-mail:qiongdian@foxmail.com

Powered by Discuz! X5.0 © 2001-2026 Discuz! Team.

在本版发帖返回顶部