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 的文件,里面包含了所有表的建表语句和对应的数据。
相关推荐
Mahir0811 小时前
Redis 与 MySQL 数据同步:一致性保证的完整解决方案
数据库·redis·mysql·缓存·面试·数据一致性
程序员陆业聪12 小时前
两次Flutter全屏白踩坑复盘:Layout的静默失败,以及AI结对编程的认知盲区
android
·醉挽清风·12 小时前
学习笔记—MySQL—库表操作
笔记·学习·mysql
程序员陆业聪13 小时前
Compose Strong Skipping Mode 的真相:它并不会让你的类型变 Stable
android
数据库小学妹14 小时前
数据库连接池避坑指南:告别“连接超时”与“资源耗尽”,让系统跑得更快!
数据库·redis·sql·mysql·缓存·dba
前进的李工14 小时前
EXPLAIN输出格式全解析:JSON、TREE与可视化
开发语言·数据库·mysql·性能优化·explain
达梦产品与服务14 小时前
稳扎稳打,持续迭代 | SQLark V3.10 更新,30+ 项优化与修复
mysql·oracle·达梦数据库·pg·sqlark百灵连接
shizhan_cloud17 小时前
MySQL 索引优化 + 慢查询日志
数据库·mysql
Drache_long17 小时前
MySQL数据库(故障排除)
数据库·mysql
shaoming377618 小时前
浏览器动作开发:地址栏图标点击事件、弹出页面设计
android·mysql·adb