服务器之家

服务器之家 > 正文

如何修改MySQL数据库名称

时间:2020-10-22 23:54     来源/作者:slicen07

比如数据库名称  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/bashmysql -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 $list_tabledo    mysql -uroot -p123456 -e "rename table old_db.$table to new_db.$table"done
mysql登陆命令行参数
  • -e, —execute=name   # 执行mysql的sql语句
  • -N, —skip-column-names   # 不显示列信息
  • -s, —silent   # 一行一行输出,中间有tab分隔

 

转转连接  http://blog.itpub.net/69982604/viewspace-2724260/

标签:

相关文章

热门资讯

2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全 2019-12-26
Intellij idea2020永久破解,亲测可用!!!
Intellij idea2020永久破解,亲测可用!!! 2020-07-29
歪歪漫画vip账号共享2020_yy漫画免费账号密码共享
歪歪漫画vip账号共享2020_yy漫画免费账号密码共享 2020-04-07
电视剧《琉璃》全集在线观看 琉璃美人煞1-59集免费观看地址
电视剧《琉璃》全集在线观看 琉璃美人煞1-59集免费观看地址 2020-08-12
最新idea2020注册码永久激活(激活到2100年)
最新idea2020注册码永久激活(激活到2100年) 2020-07-29
返回顶部