Mysql数据泵导入导出数据

一、核心命令(仅导出数据,无表结构)

sql 复制代码
mysqldump -u root -p --no-create-info powerjob > /opt/export-sql/export_powerjob_data_only.sql

关键参数说明

  • --no-create-info(简写 -t):禁用表结构导出,仅导出数据行(INSERT 语句);
  • -u root -p:指定 root 用户,执行后会提示输入密码;
  • powerjob:待导出的数据库名;
  • > /opt/export-sql/...:将导出数据覆盖写入指定文件(需确保目标目录存在)。

二、进阶需求(可选)

1. 导出数据时忽略触发器 / 存储过程(若有)

若数据库包含触发器、存储过程且无需导出,追加以下参数:

sql 复制代码
mysqldump -u root -p -t --triggers=false --routines=false powerjob > /opt/export-sql/export_powerjob_data_only.sql
  • --triggers=false:不导出触发器;
  • --routines=false:不导出存储过程 / 函数。

2. 仅导出指定表的数据(而非整个库)

sql 复制代码
# 单表
mysqldump -u root -p -t powerjob table_name1 > /opt/export-sql/export_table1_data.sql

# 多表
mysqldump -u root -p -t powerjob table_name1 table_name2 > /opt/export-sql/export_multi_tables_data.sql

3. 导出数据时带 WHERE 条件(筛选数据)

示例:仅导出 user 表中 create_time > '2025-01-01' 的数据

sql 复制代码
mysqldump -u root -p -t powerjob user --where="create_time > '2025-01-01'" > /opt/export-sql/export_user_filtered.sql

三、前置检查(避免导出失败)

1.确认目标目录存在,不存在则创建:

sql 复制代码
mkdir -p /opt/export-sql

2.确认 root 用户拥有 powerjob 数据库的 SELECT 读取权限

3.若数据量较大,追加 --quick 参数(分批读取数据,减少内存占用):

sql 复制代码
mysqldump -u root -p -t --quick powerjob > /opt/export-sql/export_powerjob_data_only.sql

四、验证导出结果

导出后检查文件内容,确认仅包含 INSERT 数据(无 CREATE TABLE 表结构语句):

sql 复制代码
# 查看文件前10行
head -10 /opt/export-sql/export_powerjob_data_only.sql

# 搜索是否有表结构语句(返回空则说明仅导出数据)
grep "CREATE TABLE" /opt/export-sql/export_powerjob_data_only.sql
相关推荐
jefl jxak22 分钟前
mysql用户名怎么看
数据库·mysql
unDl IONA27 分钟前
mysql之如何获知版本
数据库·mysql
俺不要写代码39 分钟前
数据库:约束
数据库·mysql
KmSH8umpK1 小时前
Redis分布式锁从原生手写到Redisson高阶落地,附线上死锁复盘优化方案进阶第四篇
数据库·redis·分布式
KmSH8umpK1 小时前
Redis分布式锁从原生手写到Redisson高阶落地,附线上死锁复盘优化方案进阶第五篇
数据库·redis·分布式
lilihuigz1 小时前
企业培训网站搭建指南:5步在WordPress上创建品牌学院
数据库
WL_Aurora1 小时前
MySQL 5 卸载到 MySQL 8 安装完整指南(不踩坑版)
数据库·mysql
灰阳阳1 小时前
MySQL的基本架构
数据库·mysql·架构
@小柯555m2 小时前
MySql(高级操作符--Where in 和Not in)
数据库·sql·mysql
许彰午2 小时前
CacheSQL(一):手写数据库的工程化重生
java·数据库·缓存