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

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

  1. create database new_db;
  1. mysqldump -uroot -p123456 --set-gtid-purged=OFF old_db > /tmp/old_db.sql
  2. 仅是做普通的本机备份恢复时,可以添加
  3. --set-gtid-purged=OFF
  4. 作用是在备份时候不出现GTID信息
  1. mysql -uroot -p123456 new_db < /tmp/old_db.sql

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

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

  1. create database new_db;
  1. rename table old_db.tb to new_db.tb;
  1. drop database old_db;
  • 当库下表比较多的时候,用上面方法纯手动也不现实,好在linux下可以用shell脚本来批处理。
  • 附上一个shell脚本批量修改表名称。
  1. #!/bin/bash
  2. mysql -uroot -p123456 -e \'create database if not exists new_db;\'
  3. list_table=$(mysql -uroot -p123456 -Nse "select table_name from information_schema.TABLES where TABLE_SCHEMA=\'old_db\'")
  4. for table in $list_table
  5. do
  6. mysql -uroot -p123456 -e "rename table old_db.$table to new_db.$table"
  7. done
  • -e, –execute=name # 执行mysql的sql语句
  • -N, –skip-column-names # 不显示列信息
  • -s, –silent # 一行一行输出,中间有tab分隔

版权声明:本文为easydb原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/easydb/p/13733284.html