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 的文件,里面包含了所有表的建表语句和对应的数据。
相关推荐
三少爷的鞋7 分钟前
Android 现代架构不需要事件总线进阶篇
android
杉氧15 小时前
深入理解 Compose 重组机制:快照系统如何驱动 UI 精准刷新?
android·架构·android jetpack
召钱熏15 小时前
状态枚举正确≠渲染正确:一个语音按钮的状态机边界修复实录
android·前端
杉氧15 小时前
深度解析:Jetpack Compose 核心架构与底层原理 —— 十年安卓老兵的“破茧重生”
android·架构·android jetpack
通玄16 小时前
Jetpack Compose 入门系列(七):ViewModel 与界面状态管理
android
落魄Android在线炒饭16 小时前
Android Framework 开发技巧:android.jar 生成与系统快速编译验证
android
如此风景17 小时前
Kotlin Flow操作符学习
android·kotlin
plainGeekDev17 小时前
GreenDAO → Room
android·java·kotlin
weiggle18 小时前
第八篇:ViewModel + Compose——生产级状态管理实践
android
恋猫de小郭1 天前
Amper 正式转正 Kotlin Toolchain ,Gradle 未来何去何从
android·前端·flutter