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 等专业工具
相关推荐
simplepeng5 小时前
我们都知道但总是忽略的5个Jetpack Compose细节
android·android jetpack
刮风那天5 小时前
Android 如何提高进程优先级避免被查杀?
android
修行者对6667 小时前
安卓阿里云镜像
android
刮风那天7 小时前
Android AMS创建进程不用Binder而用Socket?
android·java·binder
知行合一。。。9 小时前
Python--05--面向对象(继承,多态)
android·开发语言·python
张小潇10 小时前
AOSP15 WMS/AMS系统开发 -窗口动画源码分析
android
程序员陆业聪12 小时前
Shadow核心原理:壳子Activity与代理机制的精妙设计
android
plainGeekDev12 小时前
Android 开发者再不转Kotlin,真的来不及了
android·kotlin
赏金术士12 小时前
第五章:数据层—网络请求与Repository
android·kotlin·compose
初雪云13 小时前
让安卓发版再简单一点,体验一键自动化发布
android·运维·自动化