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";
相关推荐
倔强的石头_44 分钟前
openGauss向量数据库:引领AI时代数据智能新纪元
数据库
愚戏师1 小时前
MySQL SQL 注入
数据库·sql·mysql
摇滚侠1 小时前
2025最新 SpringCloud 教程,教程简介,笔记01
笔记·spring cloud
郑重其事,鹏程万里1 小时前
键值储存数据库(mapdb)
数据库
Kaede61 小时前
MySQL中如何使用命令行修改root密码
android·mysql·adb
c***69302 小时前
超详细:数据库的基本架构
数据库·架构
Sunhen_Qiletian2 小时前
《Python开发之语言基础》第六集:操作文件
前端·数据库·python
whn19772 小时前
达梦DW数据库安装
数据库
SelectDB2 小时前
宇信科技基于 SelectDB & Apache Doris 构建实时智能的银行经营分析平台
数据库·apache