前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >如何修改MySQL数据库名称

如何修改MySQL数据库名称

原创
作者头像
用户1685462
修改2021-09-06 11:04:17
17.8K0
修改2021-09-06 11:04:17
举报
文章被收录于专栏:网站教程
比如数据库名称old_db想改名为new_db
  • MySQL修改数据库名称比较麻烦,不支持直接修改,需要通过其它方式间接达到修改数据库名称的目的。
  • 在 MySQL 5.1.23 之前的旧版本中,我们可以使用 RENAME DATABASE 来重命名数据库,但此后版本,因为安全考虑,删掉了这一条命令。

方法一:先导出数据,再导入数据

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

1.1 先创建新库:
代码语言:javascript
复制
create database new_db;
1.2 使用mysqldump导出数据:
代码语言:javascript
复制
mysqldump -uroot -p123456 --set-gtid-purged=OFF old_db > /tmp/old_db.sql仅是做普通的本机备份恢复时,可以添加--set-gtid-purged=OFF作用是在备份时候不出现GTID信息
1.3 导入数据到新库:
代码语言:javascript
复制
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 先创建新库:
代码语言:javascript
复制
create database new_db;
2.2 使用RENAME TABLE命令修改表名,将表移动到新的库里:
代码语言:javascript
复制
rename table old_db.tb to new_db.tb;
2.3 完成后删除旧库:
代码语言:javascript
复制
drop database old_db;
2.4 如何使用shell脚本来批量修改表名:
  • 当库下表比较多的时候,用上面方法纯手动也不现实,好在linux下可以用shell脚本来批处理。
  • 附上一个shell脚本批量修改表名称。
代码语言:javascript
复制
#!/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分隔

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 比如数据库名称old_db想改名为new_db
  • 方法一:先导出数据,再导入数据
    • 1.1 先创建新库:
      • 1.2 使用mysqldump导出数据:
        • 1.3 导入数据到新库:
        • 方法二:通过修改表名称,间接实现修改数据库名称
          • 2.1 先创建新库:
            • 2.2 使用RENAME TABLE命令修改表名,将表移动到新的库里:
              • 2.3 完成后删除旧库:
                • 2.4 如何使用shell脚本来批量修改表名:
                  • mysql登陆命令行参数
              相关产品与服务
              云数据库 SQL Server
              腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
              领券
              问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档