MySQL backup.bat

html 复制代码
@echo off
chcp 65001 >nul 2>&1
setlocal enabledelayedexpansion

:::::::::::::::::::::::::::::::: CONFIGURATION ::::::::::::::::::::::::::::::::
:: MySQL Connection Settings
set "MYSQL_BIN_PATH=D:\mysql-8.0.30-winx64\bin"
set "MYSQL_USER=root"
set "MYSQL_PASS=123456"
set "MYSQL_HOST=127.0.0.1"
set "MYSQL_PORT=3306"
set "BACKUP_DB=v2"  :: 数据库名(会自动拼到文件名)

:: Backup File Settings
set "BACKUP_SAVE_PATH=C:\Users\Administrator\Desktop"  :: 备份保存目录
set "BACKUP_FILE_PREFIX=full_back"                     :: 文件名前缀
:::::::::::::::::::::::::::::::: CONFIG END ::::::::::::::::::::::::::::::::

:: 1. 生成规范日期时间(格式:年月日_时分秒,无中文/空格)
:: 处理日期:20251203(年4位+月2位+日2位)
set "DATE_YMD=%date:~0,4%%date:~5,2%%date:~8,2%"
:: 处理时间:232801(时2位+分2位+秒2位),替换空格为0(解决0-9点的空格问题)
set "TIME_HMS=%time:~0,2%%time:~3,2%%time:~6,2%"
set "TIME_HMS=!TIME_HMS: =0!"

:: 2. 拼接最终文件名:full_back_数据库名_年月日_时分秒.sql
set "BACKUP_FULL_PATH=!BACKUP_SAVE_PATH!\!BACKUP_FILE_PREFIX!_!BACKUP_DB!_!DATE_YMD!_!TIME_HMS!.sql"

:: 3. 检查 mysqldump 是否存在
if not exist "!MYSQL_BIN_PATH!\mysqldump.exe" (
    echo Error: mysqldump.exe not found! Check MYSQL_BIN_PATH.
    pause
    exit /b 1
)

:: 4. 执行备份(显示正确的文件名)
echo Backing up database [�CKUP_DB%] to: !BACKUP_FULL_PATH!
echo Please wait...

"!MYSQL_BIN_PATH!\mysqldump.exe" -u!MYSQL_USER! -p!MYSQL_PASS! -h!MYSQL_HOST! -P!MYSQL_PORT! ^
  --databases !BACKUP_DB! ^
  --single-transaction ^
  --routines ^
  --events ^
  --triggers > "!BACKUP_FULL_PATH!" 2>error.log

:: 5. 检查备份结果
if %errorlevel% equ 0 (
    echo.
    echo Success! Backup file: !BACKUP_FULL_PATH!
) else (
    echo.
    echo Error: Backup failed!
    echo Check error log: %cd%\error.log
)

endlocal
pause
相关推荐
Goat恶霸詹姆斯1 小时前
mysql常用语句
数据库·mysql·oracle
洛豳枭薰4 小时前
Innodb一次更新动作
mysql
xcLeigh5 小时前
Python 项目实战:用 Flask 实现 MySQL 数据库增删改查 API
数据库·python·mysql·flask·教程·python3
Fleshy数模6 小时前
MySQL 表创建全攻略:Navicat 图形化与 Xshell 命令行双模式实践
linux·mysql
Nandeska6 小时前
15、基于MySQL的组复制
数据库·mysql
AllData公司负责人7 小时前
AllData数据中台-数据同步平台【Seatunnel-Web】整库同步MySQL同步Doris能力演示
大数据·数据库·mysql·开源
醇氧7 小时前
【docker】mysql 8 的健康检查(Health Check)
mysql·docker·容器
lekami_兰8 小时前
MySQL 长事务:藏在业务里的性能 “隐形杀手”
数据库·mysql·go·长事务
爱学英语的程序员9 小时前
面试官:你了解过哪些数据库?
java·数据库·spring boot·sql·mysql·mybatis
·云扬·10 小时前
MySQL Redo Log落盘机制深度解析
数据库·mysql