MySQL 导出脚本

🛡️ MySQL 导出脚本

下面是整合好的完整脚本。它使用了配置文件模式 来隐藏密码(消除安全警告),并且会将数据库中所有表的结构和数据按顺序写入同一个 full_backup.sql 文件中。

准备工作:创建配置文件

为了防止密码泄露并消除警告,我们先做一个配置文件。

  1. 在电脑上新建一个文本文件,命名为 my_db.cnf

  2. 用记事本打开,粘贴以下内容(请确保密码正确):

    ini 复制代码
    [client]
    host=xxxxxx
    port=xx
    user=xxx
    password=xxxx
  3. 保存文件,记住它的存放路径(例如 D:\my_db.cnf)。

导出脚本

新建一个批处理文件(例如 export_one_file.bat),粘贴以下代码。

注意: 你需要修改脚本开头 REM --- 用户配置 --- 下方的两个路径变量。

batch 复制代码
@echo off
setlocal enabledelayedexpansion
chcp 65001 >nul
title MySQL 全库导出 (单文件版)

REM ================= 用户配置 =================
REM 1. MySQL bin 目录路径 (如果环境变量配好了,这里留空也行)
set "MYSQL_BIN_PATH=C:\Program Files\MySQL\MySQL Server 8.0\bin"

REM 2. 刚才创建的 .cnf 配置文件的绝对路径
set CONFIG_FILE=D:\my_db.cnf

REM 3. 数据库名称
set DB_NAME=XXXX

REM 4. 限制行数
set LIMIT=100
REM =============================================

REM --- 自动检测命令 ---
where mysql >nul 2>nul
if %ERRORLEVEL% EQU 0 (
    set MYSQL_CMD=mysql
    set DUMP_CMD=mysqldump
) else (
    if exist "%MYSQL_BIN_PATH%\mysql.exe" (
        set "MYSQL_CMD=%MYSQL_BIN_PATH%\mysql.exe"
        set "DUMP_CMD=%MYSQL_BIN_PATH%\mysqldump.exe"
    ) else (
        echo [错误] 找不到 mysql.exe,请检查 MYSQL_BIN_PATH 设置。
        pause
        exit /b 1
    )
)

REM --- 检查配置文件是否存在 ---
if not exist "%CONFIG_FILE%" (
    echo [错误] 找不到配置文件: %CONFIG_FILE%
    echo 请先创建包含账号密码的 .cnf 文件。
    pause
    exit /b 1
)

echo [INFO] 正在获取表列表...

REM --- 获取表名 ---
"%MYSQL_CMD%" --defaults-extra-file="%CONFIG_FILE%" --batch --skip-column-names -e "SHOW TABLES;" %DB_NAME% > temp_tables.txt

if errorlevel 1 (
    echo [错误] 连接数据库失败,请检查配置文件中的密码或网络。
    del temp_tables.txt
    pause
    exit /b 1
)

REM --- 准备输出文件 ---
set OUTPUT_FILE=full_backup_%DB_NAME%.sql
echo -- MySQL Full Backup > "%OUTPUT_FILE%"
echo -- Database: %DB_NAME% >> "%OUTPUT_FILE%"
echo -- Date: %date% %time% >> "%OUTPUT_FILE%"
echo -- Limit: %LIMIT% rows per table >> "%OUTPUT_FILE%"
echo. >> "%OUTPUT_FILE%"

echo [INFO] 开始导出到文件: %OUTPUT_FILE% ...

for /f "delims=" %%i in (temp_tables.txt) do (
    set TABLE=%%i
    echo [DATA] 正在追加表: !TABLE!
    
    REM --- 核心命令:追加导出结构和数据 ---
    REM 注意:这里没有加 --no-data 和 --no-create-info,表示两者都导出
    "%DUMP_CMD%" --defaults-extra-file="%CONFIG_FILE%" ^
        --skip-comments ^
        --default-character-set=utf8mb4 ^
        --where="true LIMIT %LIMIT%" ^
        %DB_NAME% !TABLE! >> "%OUTPUT_FILE%"
        
    REM 在每个表之间加个换行,美观一点
    echo. >> "%OUTPUT_FILE%"
)

del temp_tables.txt

echo.
echo ==========================================
echo [成功] 导出完成!
echo 文件名: %CD%\%OUTPUT_FILE%
echo ==========================================
pause

💡 关键点说明

  • >> vs > : 脚本中初始化文件时用 > (覆盖),循环追加内容时用 >> (追加)。这样能保证所有表的数据都在同一个文件里。
  • 参数解释 :
    • --where="true LIMIT 100": 限制每表只导出100条。
    • --default-character-set=utf8mb4: 防止中文乱码。
    • --skip-comments: 去掉 mysqldump 生成的多余注释头,让文件更干净。
  • 结果 : 运行结束后,你只会得到一个名为 full_backup_yhp_zg_fawkes_module.sql 的文件,里面包含了所有表的建表语句和对应的数据。
相关推荐
禹凕2 小时前
MYSQL——基础知识(SQL事务)
sql·mysql
Fate_I_C2 小时前
Android Navigation的使用说明
android·kotlin·navigation
coNh OOSI2 小时前
如何在 Windows 上安装 MySQL(保姆级教程2024版)
数据库·windows·mysql
SeSs IZED2 小时前
MySQL中查看表结构
数据库·mysql·oracle
JJay.2 小时前
高通 GAIA v1/v2/v3 共存时,Android 端该怎么做协议分层
android
极客on之路11 小时前
mysql explain type 各个字段解释
数据库·mysql
代码雕刻家11 小时前
MySQL与SQL Server的基本指令
数据库·mysql·sqlserver
lThE ANDE11 小时前
开启mysql的binlog日志
数据库·mysql
哑巴湖小水怪11 小时前
Android的架构是四层还是五层
android·架构