批处理实现MySQL数据库备份与还原

 更新时间:2024年02月23日 10:32:05   作者:川哥编程  
数据库备份的重要性和必要性是必不可少的,本文主要介绍了批处理实现MySQL数据库备份与还原,具有一定的参考价值,感兴趣的可以了解一下
(福利推荐:【腾讯云】服务器最新限时优惠活动,云服务器1核2G仅99元/年、2核4G仅768元/3年,立即抢购>>>:9i0i.cn/qcloud

(福利推荐:你还在原价购买阿里云服务器?现在阿里云0.8折限时抢购活动来啦!4核8G企业云服务器仅2998元/3年,立即抢购>>>:9i0i.cn/aliyun

数据库备份文件,例如保存为:dump_msyql.bat

REM 数据库备份
@echo off

REM 激活延迟环境变量扩展,防止变量赋值丢失
setlocal enabledelayedexpansion

REM 获取当天时间
set today=%date:~8,2%

REM 大前天,当天-3天,小于10,前面补0 
set /a daysAgo=%today%-3
if %daysAgo% lss 10 (
	set daysAgo=0%daysAgo%
)

REM 获得年+月,例如:202306
set date=%date:~0,4%%date:~5,2%

REM 今天要备份的目录
set today_dir=MySQL_Backup\%date%%today%

REM 三天前要删除的备份目录
set ago_dir=MySQL_Backup\%date%%daysAgo%

REM 创建今天备份的目录
if not exist %today_dir% (
	mkdir %today_dir%
)

REM 静默删除3天前的备份
if exist %ago_dir% (
	rd /s /q %ago_dir%
)

set dbs=MySQL_DbName1 MySQL_DbName2 MySQL_DbNameN
for %%i in (%dbs%) do (
	REM 将SQL脚本备份为压缩文件,需要安装 gzip 压缩程序并设置环境变量(大数据量推荐采用压缩)。
	mysqldump.exe -uroot -pDatabasePassword %%i | gzip.exe > %today_dir%\%%i.sql.gz
	
	REM 将SQL脚本备份为原始文件大小(小数据量推荐采用非压缩)。
	REM mysqldump.exe -uroot -pDatabasePassword %%i > %today_dir%\%%i.sql
)

pause

数据库还原文件,例如保存为:restore_msyql.bat

REM 数据库还原
@echo off
setlocal enableDelayedExpansion

set dbs=MySQL_DbName1 MySQL_DbName2 MySQL_DbNameN
for %%i in (%dbs%) do (
	REM mysql.exe -h127.0.0.1 -P3306 -uroot -pDatabasePassword -e "CREATE DATABASE IF NOT EXISTS `%%i` DEFAULT CHARACTER SET utf8 
	REM COLLATE utf8_general_ci;"
	REM 非解压缩还原。
	mysql.exe -h127.0.0.1 -P3306 -uroot -pDatabasePassword %%i < D:\MySQL_Backup\%%i.sql
	
	REM 解压缩还原。
	REM gzip -d < D:\MySQL_Backup\%%i.sql.gz | mysql -uroot -pDatabasePassword %%i
)
pause

 到此这篇关于批处理实现MySQL数据库备份与还原的文章就介绍到这了,更多相关批处理实现MySQL数据库备份与还原内容请搜索程序员之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持程序员之家!

您可能感兴趣的文章:

相关文章

最新评论

?


http://www.vxiaotou.com