MySQL 数据导出

1. 核心导出方式一:SELECT...INTO OUTFILE 语句

(1)基本说明

  • 作用:将 MySQL 查询结果直接导出到服务器端的文本文件
  • 核心属性:✅ 是 LOAD DATA INFILE 的逆操作(后者用于将文件导入数据库)✅ 执行需拥有 FILE 权限,输出文件路径需 MySQL 服务器具备写入权限✅ 输出文件不可重复创建(防止原有数据被篡改)✅ UNIX 系统下,文件归 MySQL 服务器所有,仅可读,可能无法直接删除

(2)基本语法

复制代码
SELECT column1, column2, ...
INTO OUTFILE 'file_path'
[FIELDS TERMINATED BY '分隔符']  -- 配置列分隔符,如逗号、制表符
[LINES TERMINATED BY '分隔符']   -- 配置行分隔符,如\n(换行)、\r\n
FROM your_table
WHERE your_conditions;

(3)典型实例

导出 users 表 id/name/email 列为 CSV 格式:

复制代码
SELECT id, name, email
INTO OUTFILE '/tmp/user_data.csv'
FIELDS TERMINATED BY ','
LINES TERMINATED BY '\n'
FROM users;

导出为带双引号包裹值的 CSV 格式:

复制代码
SELECT * FROM passwd INTO OUTFILE '/tmp/runoob.txt'
FIELDS TERMINATED BY ',' ENCLOSED BY '"'
LINES TERMINATED BY '\r\n';

2. 核心导出方式二:mysqldump 命令行工具

(1)基本说明

  • 作用:MySQL 官方备份工具,生成包含 CREATE TABLE、INSERT 等命令的 SQL 脚本
  • 核心特点:支持导出整库、指定表、仅数据库结构、压缩文件,可实现跨主机数据传输

(2)基本语法

复制代码
mysqldump -u 用户名 -p 密码 -h 主机名 数据库名 [表名] > 输出文件.sql

参数说明

参数 作用
-u 指定 MySQL 登录用户名
-p 提示输入密码(建议不直接写在命令中,避免密码泄露)
-h 指定远程 MySQL 主机地址(本地连接可省略)
--no-data 仅导出数据库结构,不包含数据
--all-databases 导出 MySQL 服务器中所有数据库(MySQL 3.23.12 及以上版本支持)

(3)常见场景实例

导出场景 命令示例
导出整个数据库 mysqldump -u root -p mydatabase > mydatabase_backup.sql
导出数据库中指定表 mysqldump -u root -p mydatabase mytable > mytable_backup.sql
仅导出数据库结构 mysqldump -u root -p --no-data mydatabase > mydatabase_struct.sql
导出并压缩文件 mysqldump -u root -p mydatabase | gzip > mydatabase_backup.sql.gz
远程数据库拷贝到本地 mysqldump -h 远程 IP -P 端口 -u root -p mydatabase > dump.txt

(4)跨主机数据传输

本地导出后导入远程数据库(需提前在远程创建数据库):

复制代码
# 步骤1:本地导出数据
mysqldump -u root -p mydatabase > dump.txt
# 步骤2:导入远程数据库
mysql -u root -p -h other-host.com mydatabase < dump.txt

直接通过管道传输到远程数据库(需两台服务器互通):

复制代码
mysqldump -u root -p mydatabase | mysql -h other-host.com mydatabase

3. 常见错误及解决

(1)错误提示

The MySQL server is running with the --secure-file-priv option so it cannot execute this statement

(2)错误原因

未配置 MySQL 导出文件的合法路径,或导出路径不在secure_file_priv配置范围内

(3)解决步骤

  1. 登录 MySQL,执行命令查看配置:show variables like '%secure%';
  2. 若查询结果中secure_file_priv为 null,修改配置文件:
    • Windows:编辑 my.ini,在[mysqld]节点下添加secure_file_priv=E:/TEST(自定义合法路径)
    • Linux:编辑 my.cnf,在[mysqld]节点下添加secure_file_priv=/tmp/mysql_export
  3. 重启 MySQL 服务,使配置生效
  4. 导出时指定配置的合法路径:select * from tb_test into outfile "E:/TEST/test.txt";
相关推荐
zhdy567899 分钟前
最简单方法 设置matlab坐标轴刻度标签的字号,设置坐标轴标题和图形标题,并指定字号。画出的图片背景设置为白色,
笔记
崇山峻岭之间24 分钟前
Matlab学习笔记02
笔记·学习·matlab
木木em哈哈25 分钟前
C语言多线程
笔记
有想法的py工程师30 分钟前
PostgreSQL + Debezium CDC 踩坑总结
数据库·postgresql
Nandeska44 分钟前
2、数据库的索引与底层数据结构
数据结构·数据库
小卒过河01041 小时前
使用apache nifi 从数据库文件表路径拉取远程文件至远程服务器目的地址
运维·服务器·数据库
过期动态1 小时前
JDBC高级篇:优化、封装与事务全流程指南
android·java·开发语言·数据库·python·mysql
Mr.朱鹏1 小时前
SQL深度分页问题案例实战
java·数据库·spring boot·sql·spring·spring cloud·kafka
一位代码1 小时前
mysql | 常见日期函数使用及格式转换方法
数据库·mysql
SelectDB1 小时前
Apache Doris 4.0.2 版本正式发布
数据库·人工智能