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
相关推荐
Wave8455 分钟前
非阻塞按键(单击,双击,长按)
数据库
2401_8318249611 分钟前
为你的Python脚本添加图形界面(GUI)
jvm·数据库·python
久违的太阳12 分钟前
记录一次ORACLE RAC安装PSU补丁步骤
数据库·oracle
2401_8796938713 分钟前
用Pygame开发你的第一个小游戏
jvm·数据库·python
xushichao198922 分钟前
实战:用OpenCV和Python进行人脸识别
jvm·数据库·python
sthnyph35 分钟前
初识MySQL · 库的操作
数据库·mysql
原来是猿36 分钟前
MySQL【视图】
数据库·mysql
2401_873587821 小时前
MySQL——事务管理
数据库·mysql
探索宇宙真理.1 小时前
SiYuan SQL漏洞 | CVE-2026-29073复现&研究
数据库·经验分享·sql·eureka·安全漏洞·siyuan
2501_945423541 小时前
工具、测试与部署
jvm·数据库·python