广告
返回顶部
首页 > 资讯 > 数据库 >MySQL数据库如何改名
  • 819
分享到

MySQL数据库如何改名

mysql 2023-03-14 20:03:57 819人浏览 安东尼
摘要

这篇“Mysql数据库如何改名”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“mysql数据

这篇“Mysql数据库如何改名”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“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

批量删除存储过程:

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

批量删除触发器:

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数据库如何改名”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网数据库频道。

您可能感兴趣的文档:

--结束END--

本文标题: MySQL数据库如何改名

本文链接: https://www.lsjlt.com/news/199826.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MySQL数据库如何改名
    这篇“MySQL数据库如何改名”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“MySQL数据...
    99+
    2023-03-14
    mysql
  • 【Mysql】改数据库库名操作
    MySQL在5.1引入了一个rename database操作,但在MySQL5.1.23后又不支持这个命令。可以说是一个实验性的功能,没有在生产中支持过(mysql-5.1 release在mysql...
    99+
    2022-10-18
  • 如何在mysql中修改数据库名
    如何在mysql中修改数据库名?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。方法:一般我们选择通过修改表名称来间接实现修改数据库名称。创建新库:create da...
    99+
    2023-06-14
  • 修改MySQL 数据库名称
    MySQL不支持直接修改数据库名称语法。 那么要修改数据库名称该如何操作呢?例如,我们将数据库test 修改为test2。 第一步 创建新名称对应的数据库 create database if not exists test2 第二步 获取...
    99+
    2023-10-27
    数据库 mysql
  • MySQL数据库怎么改名
    这篇文章主要介绍了MySQL数据库怎么改名,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。PS:如下操作最好提前先做一次数据库的备份以防万一,...
    99+
    2022-10-18
  • 技术分享 | MySQL 数据库如何改名?
    作者:杨涛涛 资深数据库专家,专研 MySQL 十余年。擅长 MySQL、PostgreSQL、MongoDB 等开源数据库相关的备份恢复、SQL 调优、监控运维、高可用架构设计等。目前任职于爱可生,为各大运营商及银行金融企业提供 MyS...
    99+
    2020-04-24
    技术分享 | MySQL 数据库如何改名?
  • MySQL中如何快速更改数据库名称
    本篇内容主要讲解“MySQL中如何快速更改数据库名称”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“MySQL中如何快速更改数据库名称”吧!1、新建数据库centos_old.mysql ...
    99+
    2023-06-27
  • linux MySQL怎么更改数据库名
    这篇文章主要介绍“linux MySQL怎么更改数据库名”,在日常操作中,相信很多人在linux MySQL怎么更改数据库名问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”li...
    99+
    2022-10-18
  • 怎么修改mysql数据库名称
    修改mysql数据库名称的方法:重命名所有的表,代码:CREATE DATABASE new_db_name;RENAME TABLE db_name.table1 TO new_...
    99+
    2022-10-08
  • mysql数据库改名的三种方法
    前不久去面试,被问到Innodb引擎的表如何改数据库名,当时我也只回答了MyISAM改如何操作,被一些细节问题打败,真是操蛋。如果表示MyISAM那么可以直接去到数据库目录mv就可以。Innodb完全不行,...
    99+
    2022-10-18
  • 修改mysql数据库名字的方法
    这篇文章主要介绍了修改mysql数据库名字的方法,具有一定借鉴价值,需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获。下面让小编带着大家一起了解一下。改mysql数据库名称的方法:首先创建目标库;然后...
    99+
    2022-10-18
  • mysql5.7数据库改名
    数据库版本是5.7.17 今天接到需求说需要把数据库的名字从A改为B,查了下A数据库下有不到200张表,也不是很大,要是用导入导出也可以,就是还是会慢,时间宝贵啊,用的时间越少越好。 有个rename...
    99+
    2022-10-18
  • MySQL数据库改名的详细方法教程
    目录前戏被取消的命令mysqldump 导入导出改整库的表名古老的方案总结前戏 有时候生产环境是以项目来命名,有时候会出现更名情况,其实如何安全的更改数据库名,是个非常棘手的问题,特别是针对 MySQL 来数据库来说 被...
    99+
    2023-03-13
    mysql数据库名改名 mysql数据库改名字 mysql数据库名修改
  • 织梦cms数据库名称如何修改
    这篇文章主要介绍了织梦cms数据库名称如何修改的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇织梦cms数据库名称如何修改文章都会有所收获,下面我们一起来看看吧。 ...
    99+
    2023-02-28
    cms 数据库
  • mysql数据库如何修改端口
    1、登录mysql界面 mysql -u root -p (root:mysql 名称) 键入mysql密码后此页面即正确: 2、查看端口号 show global variables like 'port'; (注意最后的封号) 3、...
    99+
    2023-08-19
    mysql 数据库 java
  • MySQL怎么修改数据表名?
     修改MySQL表名语句的关键语句”RENAME TO"其语法如下:ALTER TABLE 表名1 RENAME TO 表名2;首先打开mysql工具(以Navacate for mys...
    99+
    2022-10-18
  • oracle 11g如何修改数据库名字和实例名字
    这篇文章主要为大家展示了“oracle 11g如何修改数据库名字和实例名字”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“oracle 11g如何修改数据库名字和...
    99+
    2022-10-18
  • ORACLE RAC数据库修改名称
    1.关闭一个实例[oracle@rac11g2 ~]$ sqlplus / as sysdba SQL> shutdown imm...
    99+
    2022-10-18
  • 修改Mysql数据库的用户名和密码【详细】
    数据库的用户名默认是root 1进入到Mysql         首先要登录数据库         1win+r输入cmd【管理员身份打开】或者  2搜索输入命令提示符。 2 输入mysql -uroot -p点击回车         注...
    99+
    2023-09-09
    mysql 数据库
  • 如何用PHP修改MySQL数据库中的数据
    PHP 是一种使用最广泛的开源通用脚本语言,可嵌入到 HTML 中。它是服务器端语言,可以与 MySQL 数据库配合使用。在本文中,我们将讨论如何使用 PHP 修改 MySQL 数据库中的数据。我们假设你已经安装好了 Apache、PHP ...
    99+
    2023-05-14
    php mysql 数据库
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作