【MySQL】mysqldump使用方法

mysqldump 基本语法

备份单个数据库的基本命令格式:

bash 复制代码
mysqldump -u [username] -p[password] [database_name] > [output_file.sql]
  • -u 指定用户名
  • -p 后接密码(无空格),若未直接输入密码,执行后会提示输入
  • [database_name] 需替换为目标数据库名
  • > [output_file.sql] 将输出重定向到指定SQL文件

常用参数说明

1. 备份结构+数据(默认)

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

2. 仅备份表结构

添加 --no-data 参数:

bash 复制代码
mysqldump -u root -p --no-data mydb > schema_only.sql

3. 仅备份数据

添加 --no-create-info 参数:

bash 复制代码
mysqldump -u root -p --no-create-info mydb > data_only.sql

4. 备份多个数据库

使用 --databases 参数:

bash 复制代码
mysqldump -u root -p --databases db1 db2 > multi_db_backup.sql

5. 备份所有数据库

使用 --all-databases 参数:

bash 复制代码
mysqldump -u root -p --all-databases > full_backup.sql

高级选项

1. 添加时间戳

在文件名中嵌入日期:

bash 复制代码
mysqldump -u root -p mydb > mydb_$(date +%Y%m%d).sql

2. 压缩备份文件

通过管道直接压缩:

bash 复制代码
mysqldump -u root -p mydb | gzip > backup.sql.gz

3. 忽略特定表

使用 --ignore-table 参数:

bash 复制代码
mysqldump -u root -p mydb --ignore-table=mydb.logs > filtered_backup.sql

恢复数据库

使用 mysql 命令恢复备份:

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

注意事项

  • 密码若包含特殊字符,建议使用 -p 后不接密码,通过交互输入
  • 确保执行用户有对应数据库的读写权限
  • 大型数据库备份可能耗时较长,建议在低峰期操作
相关推荐
欧亚学术8 小时前
突发!刚刚新增17本期刊被剔除!
数据库·论文·sci·期刊·博士·scopus·发表
黑白极客8 小时前
怎么给字符串字段加索引?日志系统 一条更新语句是怎么执行的
java·数据库·sql·mysql·引擎
大厂技术总监下海9 小时前
数据湖加速、实时数仓、统一查询层:Apache Doris 如何成为现代数据架构的“高性能中枢”?
大数据·数据库·算法·apache
LeenixP9 小时前
RK3576-Debian12删除userdata分区
linux·运维·服务器·数据库·debian·开发板
知行合一。。。9 小时前
Python--03--函数入门
android·数据库·python
哈里谢顿9 小时前
小探mysql覆盖索引
mysql
X***07889 小时前
理解 MySQL 的索引设计逻辑:从数据结构到实际查询性能的系统分析
数据库·mysql·sqlite
爬山算法9 小时前
Hibernate(31)Hibernate的原生SQL查询是什么?
数据库·sql·hibernate
warton889 小时前
ubuntu24 安装 proxsql 实现数据库代理
linux·运维·mysql·ubuntu
Yuiiii__9 小时前
一次并不简单的 Spring 循环依赖排查
java·开发语言·数据库