MySQL-修改数据库名称

比如数据库名称old_db
想改名为new_db
MySQL修改数据库名称比较麻烦,不支持直接修改,需要通过其它方式间接达到修改数据库名称的目的。
在 MySQL 5.1.23 之前的旧版本中,我们可以使用 RENAME DATABASE
来重命名数据库,但此后版本,因为安全考虑,删掉了这一条命令。
方法一:先导出数据,再导入数据

当数据库体积比较小时,最快的方法是使用mysqldump
命令来创建整个数据库的转存副本,然后新建数据库,再把副本导入到新数据库中。

1.1 先创建新库:

create database new_db;
1.2 使用mysqldump
导出数据:

mysqldump -uroot -p123456 --set-gtid-purged=OFF old_db > /tmp/old_db.sql

仅是做普通的本机备份恢复时,可以添加
–set-gtid-purged=OFF
作用是在备份时候不出现GTID信息
1.3 导入数据到新库:

mysql -uroot -p123456 new_db < /tmp/old_db.sql

方法二:通过修改表名称,间接实现修改数据库名称

使用此方法实际上将所有表从一个数据库移动到另一个数据库,这实际上重命名了该数据库(MySQL没有单个语句的操作),移动后原始数据库继续存在,但是里面没有表。

RENAME TABLE
:https://dev.mysql.com/doc/refman/5.7/en/rename-table.html

2.1 先创建新库:

create database new_db;

2.2 使用RENAME TABLE
命令修改表名,将表移动到新的库里:

rename table old_db.tb to new_db.tb;

2.3 完成后删除旧库:

drop database old_db;

2.4 如何使用shell
脚本来批量修改表名:

当库下表比较多的时候,用上面方法纯手动也不现实,好在linux
下可以用shell
脚本来批处理。
附上一个shell
脚本批量修改表名称。
#!/bin/bash
mysql -uroot -p123456 -e ‘create database if not exists new_db;’
list_table=$(mysql -uroot -p123456 -Nse “select table_name from information_schema.TABLES where TABLE_SCHEMA=‘old_db’”)

for table in l i s t t a b l e d o m y s q l − u r o o t − p 123456 − e " r e n a m e t a b l e o l d d b . list_table do mysql -uroot -p123456 -e "rename table old_db. listtabledomysqlurootp123456e"renametableolddb.table to new_db.$table"
done

mysql
登陆命令行参数

-e, --execute=name # 执行mysql的sql语句
-N, --skip-column-names # 不显示列信息
-s, --silent # 一行一行输出,中间有tab分隔

内容目录

比如数据库名称old_db想改名为new_db
方法一:先导出数据,再导入数据
1.1 先创建新库:
1.2 使用mysqldump导出数据:
1.3 导入数据到新库:
方法二:通过修改表名称,间接实现修改数据库名称
2.1 先创建新库:
2.2 使用RENAME TABLE命令修改表名,将表移动到新的库里:
2.3 完成后删除旧库:
2.4 如何使用shell脚本来批量修改表名:
mysql登陆命令行参数

  • 16
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值