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
相关推荐
等....7 小时前
Minio使用
数据库
win x8 小时前
Redis 使用~如何在Java中连接使用redis
java·数据库·redis
迷枫7129 小时前
DM8 数据库安装实战:从零搭建达梦数据库环境(附全套工具链接)
数据库
XDHCOM9 小时前
PostgreSQL 25001: active_sql_transaction 报错原因分析,故障修复步骤详解,远程处理解决方案
数据库·sql·postgresql
卤炖阑尾炎10 小时前
PostgreSQL 日常运维全指南:从基础操作到备份恢复
运维·数据库·postgresql
daad77711 小时前
wifi_note
运维·服务器·数据库
xixingzhe211 小时前
Mysql统计空间增量
数据库·mysql
曹牧11 小时前
PL/SQL:xml数据
oracle
程序员萌萌12 小时前
Redis的缓存机制和淘汰策略详解
数据库·redis·缓存机制·淘汰策略
不剪发的Tony老师12 小时前
SQLite 3.53.0版本发布,重要更新
数据库·sqlite