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
相关推荐
pengdott36 分钟前
Oracle RAC内存融合技术深度解析:集群性能的幕后引擎
数据库·oracle
csudata1 小时前
绿色便携版PostgreSQL发行版重磅发布
数据库·postgresql
阳光九叶草LXGZXJ2 小时前
达梦数据库-学习-48-DmDrs控制台命令(同步之Manager、CPT模块)
linux·运维·数据库·sql·学习
我科绝伦(Huanhuan Zhou)2 小时前
脚本再升级,兼容Oracle 26ai一键安装
数据库·oracle
野生绿箭侠3 小时前
Ncos 2.3.2 版本集成达梦数据库
数据库
仍然.3 小时前
MYSQL--约束
数据库·mysql
乡野码圣4 小时前
【RK3588 Android12】RCU机制
java·jvm·数据库
亓才孓4 小时前
[数据库]应该注意的细节
数据库·sql
m0_561359675 小时前
掌握Python魔法方法(Magic Methods)
jvm·数据库·python
xxxmine5 小时前
redis学习
数据库·redis·学习