MySQL 数据导出及备份方法

MySQL 数据导出及备份方法

使用 mysqldump 工具

mysqldump 是 MySQL 官方提供的逻辑备份工具,适合中小型数据库备份。

基本导出命令格式如下:

bash 复制代码
mysqldump -u [用户名] -p[密码] [数据库名] > [输出文件.sql]

导出整个数据库:

bash 复制代码
mysqldump -u root -p mydatabase > backup.sql

导出特定表:

bash 复制代码
mysqldump -u root -p mydatabase table1 table2 > tables_backup.sql

导出数据库结构(不含数据):

bash 复制代码
mysqldump -u root -p --no-data mydatabase > schema_only.sql
使用 SELECT INTO OUTFILE

适合导出单表数据为 CSV 格式:

sql 复制代码
SELECT * INTO OUTFILE '/tmp/table_export.csv'
FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '"'
LINES TERMINATED BY '\n'
FROM table_name;
物理备份(直接复制文件)

对于 InnoDB 存储引擎,可通过复制数据文件实现热备份:

  1. 执行 FLUSH TABLES WITH READ LOCK 锁定所有表
  2. 复制 /var/lib/mysql 目录下的数据库文件
  3. 执行 UNLOCK TABLES 释放锁
使用 MySQL Enterprise Backup

商业版工具,支持增量备份和热备份:

bash 复制代码
mysqlbackup --user=root --password --backup-dir=/backup backup
自动化备份脚本示例

创建每日自动备份脚本(保存为 /usr/local/bin/mysql_backup.sh):

bash 复制代码
#!/bin/bash
DATE=$(date +%Y%m%d)
mysqldump -u root -pPASSWORD --all-databases | gzip > /backup/mysql_$DATE.sql.gz
find /backup/ -type f -mtime +7 -exec rm {} \;
重要参数说明
  • --single-transaction:对 InnoDB 表执行无锁导出
  • --routines:包含存储过程和函数
  • --events:包含事件调度器
  • --triggers:包含触发器
  • --master-data=2:记录二进制日志位置(主从复制场景)
恢复数据方法

从 mysqldump 文件恢复:

bash 复制代码
mysql -u root -p mydatabase < backup.sql

从 CSV 文件导入:

sql 复制代码
LOAD DATA INFILE '/tmp/table_export.csv'
INTO TABLE table_name
FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '"'
LINES TERMINATED BY '\n';
注意事项
  • 备份前确保有足够的磁盘空间
  • 定期验证备份文件的完整性
  • 重要数据建议采用异地备份策略
  • 对于大型数据库,考虑使用 Percona XtraBackup 等专业工具
相关推荐
成都大菠萝5 小时前
Android Car CarProperty 车辆信号链路
android
敲代码的鱼6 小时前
PDF 预览与签名批注写回 支持安卓 iOS 鸿蒙 UTS插件
android·前端·ios
时光足迹7 小时前
uni-app 视频通话实战:康复师与患者视频问诊的 6 个致命 Bug 与解决方案
android·ios·uni-app
Coffeeee11 小时前
闲聊几句,Android老哥们,你们多久没做技改需求了
android·程序员·代码规范
萝卜er12 小时前
Fragment 生命周期与状态恢复-《Android深水区(四)》
android
萝卜er12 小时前
Intent 显式、隐式与 PendingIntent-《Android深水区(五)》
android
Kapaseker15 小时前
一文吃透 Kotlin 集合操作符
android·kotlin
三少爷的鞋16 小时前
Main-safe:现代Android 架构真正的分水岭
android
沐怡旸1 天前
深入解析 Android Performance Analyzer (APA) 底层架构与技术原理
android
李斯维1 天前
从历史的角度看 Android 软件架构
android·架构·android jetpack