数据库 
首页 > 数据库 > 浏览文章

MySQL数据库重命名的快速且安全方法(3种)

(编辑:jimmy 日期: 2024/11/16 浏览:3 次 )

MySQL数据库重命名的方法

Innodb引擎的表如何改数据库名,MyISAM引擎又该如何操作。

如果表是MyISAM引擎可以直接去到数据库目录mv重命名文件夹就可以。 Innodb完全不行,会提示相关表不存在。

 第一种方法:rename database 弃用了

RENAME database old_db_name TO new_db_name

这个是5.1.7到5.1.23版本可以用的,但是官方不推荐,会有丢失数据的危险

第二种方法:mysqldump 备份

1.创建需要改成新名的数据库。
2.mysqldum 导出要改名的数据库
3.删除原来的旧库(确定是否真的需要)
当然这种方法虽然安全,但是如果数据量大,会比较耗时

mysqldump -uxxxx -pxxxx -h xxxx db_name > db_name_dump.SQL #备份
mysqldump -uroot -p123456 -h127.0.0.1 test > test.sql #备份
mysql -uxxxx -pxxxx -h xxxx -e “CREATE DATABASE new_db_name”
mysql -uxxxx -pxxxx -h xxxx new_db_name < db_name_dump.SQL #还原
mysql -uxxxx -pxxxx -h xxxx -e “DROP DATABASE db_name”

第三种方法:快速且安全 遍历 rename table

我这里就用一个脚本,很简单,相信大家都看的懂

#!/bin/bash
# 假设将db_name数据库名改为new_db_name
# MyISAM直接更改数据库目录下的文件即可
mysql_login=mysql -uroot -p123456
olddb=”db_name”
newdb=”new_db_name”

#$mysql_login -e “CREATE DATABASE $newdb
$mysql_login -e 'create database if not exists $newdb'
list_table=$($mysql_login -Nse "select table_name from information_schema.TABLES
    where TABLE_SCHEMA='$olddb'")
for table in $list_table;
do
$mysql_login -e "rename table $olddb.$table to $newdb.$table"
done;
#$mysqlconn -e “DROP DATABASE $olddb”

这里用到了rename table,改表名的命令,但是如果新表名后面加数据库名,就会将老数据库的表移动到新的数据库,所以,这种方法即安全,又快速。

最后附rename用法

命令:rename table 原表名 to 新表名;

例如:在表MyClass名字更改为YouClass
mysql> rename table MyClass to YouClass;

当你执行 RENAME 时,你不能有任何锁定的表或活动的事务。你同样也必须有对原初表的 ALTER 和 DROP 权限,以及对新表的 CREATE 和 INSERT 权限。

如果在多表更名中,MySQL 遭遇到任何错误,它将对所有被更名的表进行倒退更名,将每件事物退回到最初状态。

Mysql:使用Navicat实现定时备份

一、功能描述

需实现每天将数据库中数据备份,若出现问可及时还原备份;

二、实现步骤

打开navicat点击计划
点击新建批处理作业

MySQL数据库重命名的快速且安全方法(3种)

选择要备份的数据库

MySQL数据库重命名的快速且安全方法(3种)

点击选择并保存

MySQL数据库重命名的快速且安全方法(3种)

点击上方工具条中设置计划任务

MySQL数据库重命名的快速且安全方法(3种)

点击计划,点击新建,设置执行的时间

MySQL数据库重命名的快速且安全方法(3种)

MySQL数据库重命名的快速且安全方法(3种)

设置成功,数据默认备份在C:\Users\Administrator\Documents\Navicat\MySQL\servers中;

在navicat中点击备份也可看到,点击选中备份文件即可还原备份;

认备份在C:\Users\Administrator\Documents\Navicat\MySQL\servers中;

在navicat中点击备份也可看到,点击选中备份文件即可还原备份;

MySQL数据库重命名的快速且安全方法(3种)

上一篇:mysql导入csv的4种报错的解决方法
下一篇:解决MySQL8.0时区的问题步骤
一句话新闻
微软与英特尔等合作伙伴联合定义“AI PC”:键盘需配有Copilot物理按键
几个月来,英特尔、微软、AMD和其它厂商都在共同推动“AI PC”的想法,朝着更多的AI功能迈进。在近日,英特尔在台北举行的开发者活动中,也宣布了关于AI PC加速计划、新的PC开发者计划和独立硬件供应商计划。
在此次发布会上,英特尔还发布了全新的全新的酷睿Ultra Meteor Lake NUC开发套件,以及联合微软等合作伙伴联合定义“AI PC”的定义标准。
友情链接:杰晶网络 DDR爱好者之家 南强小屋 黑松山资源网 白云城资源网 站点导航 SiteMap