@echo off
color 0D
MODE con: COLS=71 LINES=25
title mysql数据库自动备份脚本(任务计划)
set "Ymd=%date:~,4%%date:~5,2%%date:~8,2%"
set "bak_dir= D:\db_backup"
set MYSQL=C:\Program Files (x86)\MySQL\MySQL Server 5.0\bin
md %bak_dir%
@echo 开始备份数据库。
mysqldump -uroot -proot --single-transaction smartpay > %obj_dir%\%Ymd%smartpay.sql
@echo 删除七天前备份的文件。
forfiles /p "D:\db_backup" /s /m *.* /d -7 /c "cmd /c del @path"
@echo 数据库备份完成,3秒后程序退出。
ping /n 3127.0.0.1 >nulexit
xcopy新建批处理文件 backup.dat
net stop mysql
xcopy "C:\Program Files\MySQL\MySQL Server 5.0\data\piaoyi\*.*" D:\db_backup\%date:~0,10%\ /y
net start mysql
windows环境下大库需要做全+增
全备份脚本
@echo off & setlocal ENABLEEXTENSIONS# ---------- 配置项 ---------- # 备份放置的路径,加 \
set BACKUP_PATH=D:\Backup\
# 要备份的数据库名称,多个用空格分隔
set DATABASES=database1 database2 database3
# MySQL 用户名
set USERNAME=root
# MySQL 密码
set PASSWORD=123456# MySQL Bin 目录,加 \ # 如果可以直接使用 mysqldump(安装时添加 MySQL Bin 目录到了环境变量),此处留空即可
set MYSQL=D:\SERVER\MySQL\bin\
# WinRAR 自带命令行工具的可执行文件路径,长文件名注意用 Dos 长文件名书写方式
set WINRAR=C:\Progra~1\WinRAR\Rar.exe
# ---------- 以下请勿修改 ----------
set YEAR=%date:~0,4%
set MONTH=%date:~5,2%
set DAY=%date:~8,2%
# 如果在 dos 下输入 time 返回的不是 24 小时制(没有 0 填充),请自行修改此处
set HOUR=%time:~0,2%
set MINUTE=%time:~3,2%
set SECOND=%time:~6,2%
set DIR=%BACKUP_PATH%%YEAR%\%MONTH%\%DAY%\
set ADDON=%YEAR%%MONTH%%DAY%%HOUR%%MINUTE%%SECOND%# create dir ifnot exist %DIR% (
mkdir %DIR% 2>nul
)
ifnot exist %DIR% (
echo Backuppath: %DIR% not exists, create dir failed.
goto exit
)
cd /d %DIR%
# backup
echo Start dump databases...
for%%D in (%DATABASES%) do (
echo Dumping database %%D ...
%MYSQL%mysqldump -u%USERNAME% -p%PASSWORD% %%D > %%D.%ADDON%.sql 2>nul
# winrar if exist %WINRAR% (
%WINRAR% a -k -r -s -m1 -ep1 %%D.%ADDON%.rar %%D.%ADDON%.sql 2>nul
del /F /S /Q%%D.%ADDON%.sql 2>nul
)
)
echo Done:exit
增备脚本
@echo off
# ------- 配置项 ------- # 要执行的文件名 set FILE=D:\cron\cron_backup.bat
# 计划频率类型 set FREQUENCY=DAILY
# 频率,与上面的计划频率类型对应 set MODIFIER=1# 该计划执行的时间(24 小时制) set DATETIME=00:30:00# 计划的名字 set NAME="Backup Cron Job"# 计划执行用户,不建议修改 set USER="System"# ------- 以下请勿修改 -------
schtasks /Create /RU %USER% /SC %FREQUENCY% /MO %MODIFIER% /ST %DATETIME% /TN %NAME% /TR %FILE%
pause