数据库备份文件,例如保存为: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数据库备份与还原内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!
发表评论