前戏

有时候生产环境是以项目来命名,有时候会出现更名情况,其实如何安全的更改数据库名,是个非常棘手的问题,特别是针对 MySQL 来数据库来说

被取消的命令

MySQL 之前提供了一个 rename database db_old to db_new 的命令来直接对数据库改名,可能由于实现的功能不完备(比如,这条命令可能是一个超大的事务,或者是由于之前的表很多还是 MyISAM 等),后来 的版本直接取消了这条命令。

更改数据库名大致上有以下几种方案:

mysqldump 导入导出

要说最简单的方法,就是直接用 mysqldump 工具,在旧库导出再往新库导入(最原始、最慢、最容易想到)的方法:

旧库 yttdb_old 导出(包含的对象:表、视图、触发器、事件、存储过程、存储函数)time mysqldump --login-path=root_ytt --set-gtidpurged=off --single-transaction --routines --events yttdb_old > /tmp/yttdb_old.sqlreal 2m24.388suser 0m5.422ssys 0m1.120s新库 yttdb_new 导入time mysql --login-path=root_ytt -D yttdb_new < /tmp/yttdb_old.sqlreal 12m27.324suser 0m3.778ssys 0m0.947s

改整库的表名

利用 MySQL 更改表名的方法来批量把旧库的所有表依次遍历,改名为新库的表。

这种方法比第一种要快很多倍,但是没有第一步操作起来那么顺滑,不能一步到位。比如,要把数据库 yttdb_old 改名为 yttdb_new,如果数据库 yttdb_old 里只有磁盘表,那很简单,直接改名即可

alter table yttdb_old.t1 to yttdb_new.t1;

或者写个脚本来批量改,非常简单。但是一般旧库里不只有磁盘表,还包含其他各种对象。这时候可以先考虑把旧库的各种对象导出来,完了在逐一改完表名后导进去。

导出旧库 yttdb_old 下除了磁盘表的其他所有对象(存储函数、存储过程、触发器、事件)

time mysqldump --login-path=root_ytt -t -d -n --setgtid-purged=off --triggers --routines --events yttdb_old > /tmp/yttdb_old_other_object.sqlreal 1m41.901suser 0m1.166ssys 0m0.606s

视图在 MySQL 里被看作是表,因此得先查找出视图名字,再单独导出:

view_list=`mysql --login-path=root_ytt -e "SELECT table_name FROM information_schema.views WHERE table_schema='yttdb_old';" -s | tr '\n' ' '`time mysqldump --login-path=root_ytt --set-gtid-purged=off -- triggers=false yttdb_old $view_list > /tmp/yttdb_old_view_lists.sqlreal 0m0.123suser 0m0.007ssys 0m0.007s

那这些额外的对象成功导出来后,就可以在旧库里删除他们了。当然了,做这些操作之前,建议把旧库的

所有对象,包括表,都备份出来,备份方式很多,这里就不细讲了。 现在我们来依次删除这些对象:(其实除了触发器和视图外,其他的对象也可以不用删除,不过为了让改 名完后旧库清空,就必须得先删掉它们)。

为了清晰期间,我这里每种对象单独删除,也可以直接一次性全部删除。

批量删除存储函数

func_lists=`mysql --login-path=root_ytt -e "SELECT concat('drop function if exists ',routine_name,';') FROM information_schema.routines WHERE routine_schema = 'yttdb_old' AND routine_type = 1 " -ss

 time mysql --login-path=root_ytt -e "use yttdb_old;$func_lists" real 0m0.048suser 0m0.005ssys 0m0.005s

批量删除存储过程:

procedure_lists=`mysql --login-path=root_ytt -e "SELECT concat('drop procedure if exists ',routine_name,';') FROM information_schema.routines WHERE routine_schema = 'yttdb_old' AND routine_type = 2 " -ss` time mysql --login-path=root_ytt -e "use yttdb_old;$procedure_lists"real 0m0.046suser 0m0.006ssys 0m0.005s

批量删除触发器:

trigger_lists=`mysql --login-path=root_ytt -e "SELECT concat('drop trigger if exists yttdb_old.',trigger_name,';') FROM information_schema.TRIGGERS WHERE trigger_schema='yttdb_old'" -ss`time mysql --login-path=root_ytt -e "use yttdb_old;$trigger_lists"real 0m0.050suser 0m0.008ssys 0m0.003s

批量删除视图:

view_lists=`mysql --login-path=root_ytt -e "SELECT concat('drop view if exists ',table_name,';') FROM information_schema.VIEWS WHERE table_schema='yttdb_old'" -ss`time mysql --login-path=root_ytt -e "use yttdb_old;$view_lists"real 0m0.070suser 0m0.006ssys 0m0.005s

批量删除事件:

 event_lists=`mysql --login-path=root_ytt -e "SELECT concat('drop event if exists ',event_name,';') FROM information_schema.EVENTS WHERE event_schema='yttdb_old'" -ss` time mysql --login-path=root_ytt -e "use yttdb_old;$event_lists"real 0m0.054suser 0m0.011ssys 0m0.000s

完了后利用 rename table old_table to new_table 语句来批量更改表名到新库:(debian-ytt1:3500)|(yttdb_new)>set group_concat_max_len = 18446744073709551615;Query OK, 0 rows affected (0.00 sec)(debian-ytt1:3500)|(yttdb_new)>SELECT CONCAT('rename table ', GROUP_CONCAT(CONCAT(' yttdb_old.',table_name,' to yttdb_new.',table_name)) ) FROM information_schema.TABLES WHERE table_schema = 'yttdb_old' AND table_type = 1 INTO @rename_lists;Query OK, 1 row affected (0.01 sec)(debian-ytt1:3500)|(yttdb_new)>prepare s1 from @rename_lists;Query OK, 0 rows affected (0.00 sec)Statement prepared(debian-ytt1:3500)|(yttdb_new)>execute s1;Query OK, 0 rows affected (55.41 sec)(debian-ytt1:3500)|(yttdb_new)>drop prepare s1;Query OK, 0 rows affected (00.01 sec)

批量更改表名总共才花费 55.41 秒。接下来再把之前导出的其他对象导入新库 yttdb_new:

time mysql --login-path=root_ytt -D yttdb_new < /tmp/yttdb_old_other_object.sqlreal 0m0.222suser 0m0.081ssys 0m0.000stime mysql --login-path=root_ytt -D yttdb_new < /tmp/yttdb_old_view_lists.sqlreal 0m0.158suser 0m0.013ssys 0m0.000s

接下来进行功能验证,验证表数量、触发器、存储过程、存储函数、事件等数目是不是对的上。

古老的方案

其实在 MySQL 早期还有一种方法。

假设 MySQL 部署好了后,所有的 binlog 都有备份,并且二进制日志格式还是 statement 的话,那就可 以简单搭建一台从机,让它慢慢追主机到新的库名,等确切要更改旧库的时候,再直接晋升从机为主机即 可。 这里只需要从机配置一个参数来把旧库指向为新库: replicate-rewrite-db=yttdb_old->yttdb_new 不过这种局限性很大,不具备标准化,不推荐。

总结

其实针对 MySQL 本身改库名,大致就这么几种方法:

  1. 如果数据量小,推荐第一种;
  2. 数据量大,则推荐第二种;
  3. 数据量巨大,那就非 MySQL 本身能解决的了。

可通过部署第三方 ETL 工具,通过解析 MySQL 二进制日志或其他的方式来把旧库数据直接读取到新库达到改名的目的等等

MySQL数据库如何改名相关推荐

  1. mysql 数据库名字 mac,【已解决】Mac本地给mysql数据库改名

    折腾 期间,需要去备份在线mysql,恢复导入到Mac本地的mysql 但是同时保留Mac本地之前的mysql的数据库,用于对比查找问题 所以需要去: mysql 数据库 改名 mysql datab ...

  2. MySQL数据库改名

    MySQL数据库改名 某项目中有需求要将数据库改个名字,从MySQL的参考手册中发现有rename database的SQL命令,兴冲冲的执行了 mysql> rename database d ...

  3. mysql还原数据库时改名_mysql数据库可以重新命名吗

    展开全部 被取消的命令MySQL 之前提供了一个 rename database db_old to db_new 的命令来直接对e69da5e887aa62616964757a686964616f3 ...

  4. mysql数据库中nchar_MySQL数据库中CHAR与VARCHAR之争

    在MySQL数据库中,用的最多的字符型数据类型就是Varchar和Char..这两种数据类型虽然都是用来存放字符型数据,但是无论从结构还是从数 据的保存方式来看,两者相差很大.而且其具体的实现方式,还 ...

  5. linux数据库创建score表,MySQL数据库学习笔记

    MySQL数据库学习笔记phpma (实验环境:Redhat9.0,MySQL3.23.54) 纲要: 一,连接MySQL phpma 二,MySQL管理与授权 三,数据库简单操作 四, 数据库备份 ...

  6. linux mysql 更改MySQL数据库目录位置

    MySQL默认的数据文件存储目录为/var/lib/mysql.假如要把目录移到/home/data下需要进行下面几步: 1.home目录下建立data目录 cd /home mkdir data 2 ...

  7. MySQL数据库多种安装方法及企业级安装实践

    本文来自老男孩老师第三本书籍著作<老男孩的MySQL私房菜>第三章内容分享! 3.1 MySQL数据库的安装方法及选择 在当今的互联网企业里,MySQL数据库大多运行在Linux系列操作系 ...

  8. Linux下修改Mysql数据库存放路径

    Linux下修改Mysql数据库存放路径 原路径:/var/lib/mysql 目标路径:/home/data/mysql 1.home目录下建立data目录 cd /home mkdir data ...

  9. mysql world.sql.zip_安装mysql数据库zip版|mysqlzip

    在刚开始接触 mysql的时候,安装都费了好大劲,网上好多教程可能因为版本不同没办法完全对应上,东拼西凑的各种紊乱,怕以后再次需要安装的时候忘了,现在整理如下: (至于为啥是zip版,msi的步骤都感 ...

最新文章

  1. 阿里某p9哭穷:300万年薪,依然挣扎在温饱线上!
  2. h5页面笔按下默认是拖动,H5中在拖动的元素或选择的文本进入到有效的放置目标时触发的事件ondragenter...
  3. 【UIKit】UILabel使用
  4. linux fdisk等命令,Linux fdisk命令操作磁盘(添加、删除、转换分区等)
  5. android中ADT和SDK的关系(转)
  6. css不换行属性_那些不常见,但却非常实用的css属性(整理不易)
  7. 使用detours实现劫持
  8. JavaScript笔记-点击button提交form表单
  9. 三星Galaxy Z Flip 3渲染图:更窄边框 铰链升级
  10. 程序员求助:腾讯面试题,64匹马8个跑道,多少轮选出最快的四匹
  11. Java程序猿必须掌握的重点之一:Lock锁
  12. 震惊!99%的人不知道的Linux权限问题细节
  13. 《Entity Framework 6 Recipes》中文翻译系列 (11) -----第三章 查询之异步查询 (转)...
  14. UNIX网络编程卷一 学习笔记 第一章 简介
  15. win10无网络安装.Net Framework3.5
  16. 5.docker image (镜像)
  17. 疑难杂症共济失调怎么治疗恢复?
  18. 统计个人CSDN的博客文章数量
  19. 两种方法 Find inorder succ of BST
  20. BP神经网络预测公路运力

热门文章

  1. 从单机到多机:多机一定比单机快吗?秒杀系统到底有没有必要用分布式锁?
  2. 权威发布:《麻省理工科技评论》2020年“全球十大突破性技术”
  3. C# Lambda 表达式
  4. 无人值守安装linux操作系统
  5. 软路由连接NAS做链路聚合
  6. 使用CoreImage实现素描滤镜
  7. geek_2013年How-To Geek的节日礼物指南:一定要装满东西
  8. 做一个“有意思”的人
  9. 2017蓝桥杯B组国赛 瓷砖样式
  10. AWS云上部署Hadoop