MySQL技能完整学习列表10、数据导入和导出——1、数据导入(LOAD DATA, mysqldump)——2、数据导出(SELECT ... INTO OUTFILE, mysqldump)

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
云数据库 RDS MySQL,高可用系列 2核4GB
简介: MySQL技能完整学习列表10、数据导入和导出——1、数据导入(LOAD DATA, mysqldump)——2、数据导出(SELECT ... INTO OUTFILE, mysqldump)



 

数据导入(LOAD DATA, mysqldump)

MySQL提供了多种数据导入和导出的方法,其中LOAD DATAmysqldump是两个常用的命令。下面将详细说明这两个命令的使用方法,并提供具体的示例。

1. 使用LOAD DATA导入数据

LOAD DATA语句用于从文本文件或其他数据源中快速导入大量数据到MySQL表中。它可以高效地将数据加载到表中,比使用多个INSERT语句要快得多。

语法
LOAD DATA [LOW_PRIORITY | CONCURRENT] [LOCAL] INFILE 'file_name'
[REPLACE | IGNORE]
INTO TABLE table_name
[CHARACTER SET charset_name]
[FIELDS
    [TERMINATED BY 'string']
    [[OPTIONALLY] ENCLOSED BY 'char']
    [ESCAPED BY 'char']
]
[LINES
    [STARTING BY 'string']
    [TERMINATED BY 'string']
]
[IGNORE number {LINES | ROWS}]
[(col_name_or_user_var,...)]
[SET col_name = expr,...]
示例

假设我们有一个名为employees.txt的文本文件,包含员工的数据,每行表示一个员工,字段之间使用制表符(\t)分隔。文件内容如下:

1   John Doe    john.doe@example.com    45000
2   Jane Smith  jane.smith@example.com  50000
3   Bob Johnson bob.johnson@example.com 48000

要将这些数据导入到名为employees的MySQL表中,可以使用以下LOAD DATA语句:

LOAD DATA LOCAL INFILE 'employees.txt'
INTO TABLE employees
FIELDS TERMINATED BY '\t'
LINES TERMINATED BY '\n'
(id, name, email, salary);

这会将数据从employees.txt文件导入到employees表中。

2. 使用mysqldump导出数据

mysqldump是一个命令行工具,用于导出MySQL数据库的结构和数据为SQL脚本文件。它可以导出整个数据库或指定的表,并且导出的数据可以用于备份或在其他MySQL服务器上恢复数据。

语法
mysqldump [options] db_name [tbl_name ...]
mysqldump [options] --databases db_name ...
mysqldump [options] --all-databases
示例

假设我们要导出名为mydatabase的数据库的结构和数据,并将其保存到一个名为backup.sql的文件中,可以使用以下命令:

mysqldump -u username -p mydatabase > backup.sql

数据导出(SELECT ... INTO OUTFILE, mysqldump)

MySQL提供了多种数据导出的方法,其中SELECT ... INTO OUTFILEmysqldump是两个常用的命令。下面将详细说明这两个命令的使用方法,并提供具体的示例。

1. 使用SELECT ... INTO OUTFILE导出数据

SELECT ... INTO OUTFILE语句用于将查询结果导出到一个文本文件中。这种方法可以方便地将表中的数据导出为文件格式,以供其他程序或系统使用。

语法
SELECT column1, column2, ...
INTO OUTFILE 'file_name'
[CHARACTER SET charset_name]
[EXPORT_OPTIONS]
FROM table_name
[WHERE condition];
  • column1, column2, ...:要导出的列名。
  • 'file_name':导出文件的名称和路径。
  • [CHARACTER SET charset_name]:可选,指定导出文件的字符集。
  • [EXPORT_OPTIONS]:可选,导出选项,如字段分隔符、行终止符等。
  • table_name:要导出数据的表名。
  • [WHERE condition]:可选,导出满足条件的记录。
示例

假设我们有一个名为employees的表,包含员工的信息,现在我们要导出所有员工的姓名和电子邮件地址到一个名为employees.txt的文本文件中,每行一个记录,字段之间使用逗号(,)分隔。可以使用以下语句:

SELECT name, email
INTO OUTFILE 'employees.txt'
FIELDS TERMINATED BY ','
LINES TERMINATED BY '\n'
FROM employees;

这会将查询结果导出到employees.txt文件中。

2. 使用mysqldump导出数据

除了SELECT ... INTO OUTFILE,MySQL还提供了mysqldump命令行工具,用于导出数据库的结构和数据为SQL脚本文件。与SELECT ... INTO OUTFILE不同,mysqldump可以导出整个数据库或指定的表,并且导出的数据可以用于备份或在其他MySQL服务器上恢复数据。

语法
mysqldump [options] db_name [tbl_name ...]
mysqldump [options] --databases db_name ...
mysqldump [options] --all-databases
  • db_name:要导出的数据库名。
  • tbl_name:可选,要导出的表名。可以指定多个表名,用空格分隔。
  • options:可选,导出选项,如用户名、密码、导出格式等。#### 示例

假设我们要导出名为mydatabase的数据库的结构和数据,并将其保存到一个名为backup.sql的文件中,可以使用以下命令:

mysqldump -u username -p mydatabase > backup.sql
相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
相关文章
|
5月前
|
人工智能 运维 关系型数据库
数据库运维:mysql 数据库迁移方法-mysqldump
本文介绍了MySQL数据库迁移的方法与技巧,重点探讨了数据量大小对迁移方式的影响。对于10GB以下的小型数据库,推荐使用mysqldump进行逻辑导出和source导入;10GB以上可考虑mydumper与myloader工具;100GB以上则建议物理迁移。文中还提供了统计数据库及表空间大小的SQL语句,并讲解了如何使用mysqldump导出存储过程、函数和数据结构。通过结合实际应用场景选择合适的工具与方法,可实现高效的数据迁移。
997 1
|
5月前
|
存储 SQL 关系型数据库
【赵渝强老师】使用mysqldump备份MySQL
本文介绍了 MySQL 自带的逻辑备份工具 mysqldump 的使用方法。通过 mysqldump,可以将数据库中的数据转换为对应的 SQL 插入语句,便于备份和还原。文章详细说明了如何备份所有数据库、指定数据库及特定表,排除某些表不备份的操作,以及删除数据库后如何通过备份文件恢复数据。同时提供了视频讲解和具体命令示例,帮助用户更好地理解和应用该工具。
247 5
|
存储 关系型数据库 MySQL
在 MySQL 中使用 Insert Into Select
【8月更文挑战第11天】
4639 0
在 MySQL 中使用 Insert Into Select
|
关系型数据库 MySQL 数据库
MySQL mysqldump教程:轻松备份与迁移数据库
MySQL mysqldump教程:轻松备份与迁移数据库
1655 1
|
关系型数据库 MySQL Shell
MySQL 备份:从mysqldump全备中 匹配出某几个表
MySQL 备份:从mysqldump全备中 匹配出某几个表
|
SQL 存储 关系型数据库
运维笔记.MySQL.基于mysqldump数据备份与恢复
运维笔记.MySQL.基于mysqldump数据备份与恢复
303 0
|
存储 关系型数据库 MySQL
mysql mysqldump用法详解
mysql mysqldump用法详解
1100 0
|
2月前
|
缓存 关系型数据库 BI
使用MYSQL Report分析数据库性能(下)
使用MYSQL Report分析数据库性能
126 3
|
2月前
|
关系型数据库 MySQL 数据库
自建数据库如何迁移至RDS MySQL实例
数据库迁移是一项复杂且耗时的工程,需考虑数据安全、完整性及业务中断影响。使用阿里云数据传输服务DTS,可快速、平滑完成迁移任务,将应用停机时间降至分钟级。您还可通过全量备份自建数据库并恢复至RDS MySQL实例,实现间接迁移上云。

推荐镜像

更多