MySQL数据库修改库名的三种方法

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/Oracle_zsq/article/details/84135374

如果是MyISAM存储引擎那么可以直接去到数据库目录mv就可以。

如果是Innodb完全不行,会提示相关表不存在。

第一种方法:
RENAME database olddbname TO newdbname

官方不推荐,会有丢失数据的危险

第二种方法:

1.创建需要改成新名的数据库。
2.mysqldum 导出要改名的数据库
3.删除原来的旧库(确定是否真的需要)
当然这种方法虽然安全,但是如果数据量大,会比较耗时,同时还需要考虑到磁盘空间等硬件成本。

第三种方法:

直接跑一个shell脚本,

#!/bin/bash
# 假设将db1数据库名改为db2
# MyISAM直接更改数据库目录下的文件即可

mysql -uroot -p123456 -e 'create database if not exists db2'
list_table=$(mysql -uroot -p123456 -Nse "select table_name from information_schema.TABLES where TABLE_SCHEMA='db1'")

for table in $list_table
do
    mysql -uroot -p123456 -e "rename table db1.$table to db2.$table"
done

猜你喜欢

转载自blog.csdn.net/Oracle_zsq/article/details/84135374