【mysql】mysql导入导出数据详解

news2024/11/27 10:21:27

在这里插入图片描述

✨✨ 欢迎大家来到景天科技苑✨✨

🎈🎈 养成好习惯,先赞后看哦~🎈🎈

🏆 作者简介:景天科技苑
🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。
🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi,flask等框架,linux,shell脚本等实操经验,网站搭建,数据库等分享。

所属的专栏:MySQL数据库入门,进阶应用实战必备
景天的主页:景天科技苑

文章目录

  • 一、导出数据库
    • (一)使用SELECT … INTO OUTFILE语句将某个表中的数据导出
    • (二)使用mysqldump工具导出数据
    • (三)导出步骤
      • 1.原服务器操作
      • 2.新服务器导入原来的数据库
  • 二、导入数据
    • (一)load data参数详解
    • (二)执行导入

大家好,我是景天,本文主要介绍了MySQL 导出和导入数据的几种实现方式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

一、导出数据库

MySQL导出数据的主要作用是将数据库中的数据以某种格式(如SQL、CSV等)导出到一个文件中,以便在需要时进行导入或备份。

导出数据的作用包括但不限于以下几个方面:

数据备份:导出数据可以将数据库中的数据备份到文件中,以防止数据丢失或意外删除。
数据迁移:如果需要将数据库从一个服务器迁移到另一个服务器,可以将数据导出到文件中,然后在目标服务器上导入数据。
数据共享:如果需要与其他人共享数据库中的数据,可以将数据导出到CSV等通用格式的文件中,然后将其发送给其他人。
数据分析:如果需要对数据库中的数据进行分析或处理,可以将其导出到文件中,然后使用其他工具(如Excel、Python等)进行处理。

(一)使用SELECT … INTO OUTFILE语句将某个表中的数据导出

SELECT … INTO OUTFILE语句是MySQL中用于将查询结果导出为CSV文件的方法。它允许您将查询结果保存到指定的文件路径中,以便进行后续处理或备份。
使用案例:
在这里插入图片描述

我们有一个名为"students"的表格,其中包含班级、男生人数、女生人数。要导出这些数据到一个CSV文件中,可以使用以下语句:

select * into outfile '/data/file.csv' 
FIELDS TERMINATED BY ',' 
ENCLOSED BY '"' 
LINES TERMINATED BY '\n' 
from students;

这将导出"students"表中的所有数据,并将其保存到指定路径的CSV文件中。文件中的每行代表一个用户,每个字段用逗号分隔,并用双引号包围。

参数说明:

INTO OUTFILE ‘file_path’: 指定要导出数据的文件路径。可以是本地路径或Web服务器上的路径。 FIELDS
TERMINATED BY ‘delimiter’: 指定字段之间的分隔符。默认情况下使用制表符(\t)作为分隔符。 ENCLOSED BY
‘enclosure’: 指定字段内容的引号包围符号。默认情况下不使用引号包围。 LINES TERMINATED BY
‘line_break’: 指定每行数据之间的分隔符。默认情况下使用换行符(\n)作为行分隔符。 FROM table_name:
指定要导出数据的表格名称。

注意事项:

使用SELECT … INTO OUTFILE语句导出数据需要具有相应的权限。确保您具有足够的权限来执行此操作。
导出的文件路径必须是MySQL服务器可以访问的路径。如果路径无法访问,您将无法导出数据。
如果指定的文件已经存在,将会覆盖该文件。请确保在导出数据之前备份重要的文件。

执行这句可能会报错如下
mysql> select * into outfile ‘/data/file.csv’ FIELDS TERMINATED BY ‘,’ ENCLOSED BY ‘"’ LINES TERMINATED BY ‘\n’ from students;
ERROR 1290 (HY000): The MySQL server is running with the --secure-file-priv option so it cannot execute this statement
在这里插入图片描述

【1】分析原因

其实原因很简单,因为在安装MySQL的时候限制了导入与导出的目录权限。只允许在规定的目录下才能导入。

可以通过以下命令查看secure-file-priv当前的值是什么

SHOW VARIABLES LIKE "secure_file_priv";

mysql8.0默认目录是/var/lib/mysql-files/
在这里插入图片描述

可以看到,本地value的值为/var/lib/mysql-files/。经查资料,value的值有可能有如下几种:
(1)NULL,表示禁止。

(2)如果value值有文件夹目录,则表示只允许该目录下文件(PS:测试子目录也不行)。

(3)如果为空,则表示不限制目录。

【2】解决方案

去掉导入的目录限制。可修改mysql配置文件(Windows下为my.ini, Linux下的/etc/my.conf),在[mysqld]下面,查看是否有:

secure_file_priv =

如上这样一行内容,如果没有,则手动添加。如果存在如下行:

secure_file_priv = /home 

这样一行内容,表示限制为/home文件夹。而如下行:

secure_file_priv =

这样一行内容,表示不限制目录,等号一定要有,否则mysql无法启动。
修改完配置文件后,重启mysql生效。

在这里插入图片描述

重启数据库

systemctl restart mysqld.service

在这里插入图片描述

默认只能指定 /tmp目录 。否则回报 “ ERROR 1 (HY000) at line 1: Can’t create/write to file ‘/xxxx/xxxx/xxx.csv’ (Errcode: 13)” 错误 !导致原因是因为权限问题,修改起来比较麻烦 !可以放到/tmp/目录下,然后cp到其它你想存放的目录。【推荐使用这种方法】
导出到/data/目录报权限不足
在这里插入图片描述

导出到tmp/目录成功
在这里插入图片描述
在这里插入图片描述

下载到本地打开
在这里插入图片描述

(二)使用mysqldump工具导出数据

mysqldump是MySQL数据库的一个命令行工具,用于备份和导出数据库、表格和数据。以下是使用mysqldump工具导出数据的基本语法:

mysqldump -u username -p dbname table_name > /path/to/output/file.sql

参数说明

-u: 指定MySQL的用户名。
-p: 表示需要输入密码。 dbname: 指定要导出数据的数据库名称。 table_name: 指定要导出数据的表格名称。如果要导出整个数据库,可以省略该参数。 /path/to/output/file.sql:
指定导出数据的输出文件路径。

导出整个数据库可以使用如下命令:
mysqldump –u用户名 p密码 -d 数据库名 表名 > 脚本名

导出单个数据库结构和数据:

mysqldump -uroot -pJxxxxxx357@  --databases  db005 >dump2.sql

导出单个数据库中单个表结构和数据: 数据库名 表名

mysqldump -uroot -pJixxxxxxx7@   db005  t1 >dump3.sql

导出整个数据库结构(不包含数据):

mysqldump -h localhost -uroot -p123456 -d database > dump.sql

只包含数据库和表结构,不包含数据

mysqldump -uroot -pJinghao31357@ -d db001 >dump.sql

导出单个数据表结构(不包含数据):

mysqldump -h localhost -uroot -p123456 -d database table > dump.sql

导出全部数据库数据:

mysqldump -uroot -p --all-databases > alldb.sql

(三)导出步骤

1.原服务器操作

1.指定到处对应的数据库文件

mysqldump -uroot -pJinghao31357@ --all-databases --single-transaction > `date +%Y%m%d%H`-mysal-all.sql

–single-transaction :让整个数据在dump过程中保证数据的一致性,这个选项对InnoDB的数据表很有用,且不会锁表。
但是这个不能保证MyISAM表和MEMORY表的数据一致性。

备份指定数据库指定表(多个表以空格间隔)

mysqldump -uroot -p  mysql db event > /backup/mysqldump/2table.sql

导出特定数据库的所有表格的表结构及其数据,添加“–databases ”命令参数

mysqldump  -u  b_user -h 101.3.20.33 -p'H_password' -P3306 --databases test  > all_database.sql
-A = --all-databases 全库备份
-B =  --databases 部分库备份

2.将备份的sql语句scp到指定服务器

scp 2020081222-maysl-all.sql root@10.0.0.51:/root/

2.新服务器导入原来的数据库

这种方式不用登录数据库
利用备份的sql语句导入,复原旧服务器数据

mysql -uroot -pJinghao31357@ < 2020081222-maysl-all.sql

二、导入数据

(一)load data参数详解

在MySQL中,您可以使用LOAD DATA语句将外部数据文件导入到数据库中。LOAD DATA语句允许您以高效的方式将大量数据快速加载到数据库表中。

以下是使用LOAD DATA导入数据的基本语法:

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

逐个解释这些选项的含义:

LOW_PRIORITY:该选项可用于降低LOAD
DATA语句的优先级,以便它不会与其他查询竞争资源。这在需要同时运行其他重要查询的系统上是有用的。
CONCURRENT:该选项允许在导入数据的同时进行其他操作,而不会相互干扰。
LOCAL:该选项指示从客户端系统上的文件加载数据,而不是从服务器上的文件加载。 INFILE
‘file_name’:指定要导入的数据文件的路径和名称。 REPLACE:如果存在重复的记录,该选项将删除现有记录并用新记录替换它们。
IGNORE:如果存在重复的记录,该选项将忽略新记录,保留现有记录。 INTO TABLE
table_name:指定要将数据导入的目标表的名称。 CHARACTER SET charset_name:指定用于解析文件的字符集。
FIELDS TERMINATED BY ‘string’:指定字段之间的分隔符。 ENCLOSED BY
‘char’:指定字段内容的引号包围符号。 ESCAPED BY ‘char’:指定用于转义特殊字符的转义符号。 LINES
TERMINATED BY ‘string’:指定每行数据之间的分隔符。 IGNORE number {LINES |
ROWS}:指定要忽略的行数或行数范围。 (column_name_or_user_var,…):指定要导入的列名或用户变量。 SET
column_name = expr,…:设置要导入的列的值。

导入案例:
我们把刚才导出的file.csv改一下
在这里插入图片描述

(二)执行导入

load data infile '/tmp/file.csv' into table students FIELDS TERMINATED BY ',' ENCLOSED BY '"' LINES TERMINATED BY '\n';

在这里插入图片描述

查看数据库,导入成功
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1659612.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

计算机毕业设计系列~~~基于SSM的宠物销售网站

目录 一、项目介绍 二、开题报告 三、项目截图 一、项目介绍 本项目是一款基于SSM的宠物销售网站&#xff0c;主要针对计算机相关专业的正在做毕设的学生与需要项目实战练习的 Java 学习者。 1. 包含&#xff1a;项目源码、项目文档、数据库脚本、软件工具等所有资料 2. …

Web实时通信的学习之旅:WebSocket入门指南及示例演示

文章目录 WebSocket的特点1、工作原理2、特点3、WebSocket 协议介绍4、安全性 WebSocket的使用一、服务端1、创建实例&#xff1a;创建一个webScoket实例对象1.1、WebSocket.Server(options[&#xff0c;callback])方法中options对象所支持的参数1.2、同样也有一个加密的 wss:/…

llama.cpp制作GGUF文件及使用

llama.cpp的介绍 llama.cpp是一个开源项目&#xff0c;由Georgi Gerganov开发&#xff0c;旨在提供一个高性能的推理工具&#xff0c;专为在各种硬件平台上运行大型语言模型&#xff08;LLMs&#xff09;而设计。这个项目的重点在于优化推理过程中的性能问题&#xff0c;特别是…

【Oracle直播课】5月19日Oracle 19c OCM认证大师课 (附课件预览)

Oracle 19c OCM认证大师培训 - 课程体系 - 云贝教育 (yunbee.net) 部分课件预览 OCM部分课件预览 Oracle Database 19c Certified Master Exam (OCM) 认证大师 25 天 / 150课时 什么是Oracle 19c OCM&#xff1f; Oracle Certified Master (OCM)是Oracle认证大师&#xff0c;…

东南亚电商市场新趋势:自养号测评助力Shopee和Lazada卖家脱颖而出

在东南亚电商市场中&#xff0c;Shopee和Lazada无疑是两大巨头。对于卖家而言&#xff0c;如何在竞争激烈的平台上脱颖而出&#xff0c;提升产品曝光度和销量&#xff0c;一直是他们关注的焦点。而自养号测评作为一种有效的营销手段&#xff0c;正逐渐被越来越多的卖家所采用。…

经济学SSCI期刊,中科院3区,IF=2+,难度不大,收稿范围广泛!

一、期刊名称 Information Economics and Policy 二、期刊简介概况 期刊类型&#xff1a;SSCI 学科领域&#xff1a;经济学 影响因子&#xff1a;2.8 中科院分区&#xff1a;3区 出版方式&#xff1a;订阅模式/开放出版 版面费&#xff1a;选择开放出版需支付$3190 三、…

Spring Boot 中集成 EasyExcel 实现 Excel 文件读写操作

&#x1f341; 作者&#xff1a;知识浅谈&#xff0c;CSDN签约讲师&#xff0c;CSDN博客专家&#xff0c;华为云云享专家&#xff0c;阿里云专家博主 &#x1f4cc; 擅长领域&#xff1a;全栈工程师、爬虫、ACM算法 &#x1f492; 公众号&#xff1a;知识浅谈 &#x1f525; 微…

【QA】Java集合常用的函数

文章目录 前言Collection接口通用函数 | Collections工具类通用函数 | List接口 Set接口List接口ArrayListLinkedList Set接口TreeSetHashSetLinkedHashSet Map接口通用函数TreeMapHashMapLinkedHashMap 前言 本文介绍Java集合中常用的函数。 Collection接口 通用函数 | Co…

正点原子Linux学习笔记(七)在 LCD 上显示 png 图片

在 LCD 上显示 png 图片 21.1 PNG 简介21.2 libpng 简介21.3 zlib 移植下载源码包编译源码安装目录下的文件夹介绍移植到开发板 21.4 libpng 移植下载源码包编译源码安装目录下的文件夹介绍移植到开发板 21.5 libpng 使用说明libpng 的数据结构创建和初始化 png_struct 对象创建…

Mysql 8.0 -- 最新版本安装(保姆级教程)

Mysql 8.0 -- 最新版本安装&#xff08;保姆级教程&#xff09; ​​ 一&#xff0c;下载Mysql数据库&#xff1a; 官网链接&#xff1a;https://www.mysql.com/downloads/ 二&#xff0c;安装Mysql: 三&#xff0c;找到Mysql安装目录&#xff1a; 找到mysql安装目录&#xf…

Chronos:学习时间序列的大语言模型(代码解析)

前言 《Chronos: Learning the Language of Time Series》原文地址&#xff0c;Github开源代码地址Chronos&#xff1a;学习时间序列的大语言模型&#xff08;论文解读&#xff09;CSDN地址GitHub项目地址Some-Paper-CN。本项目是译者在学习长时间序列预测、CV、NLP和机器学习…

vue多选功能

废话不多说&#xff0c;直接上代码&#xff01;&#xff01;&#xff01; <template><div class"duo-xuan-page"><liv-for"(item, index) in list":key"index"click"toggleSelection(item)":class"{ active: sel…

加密“发射台”:未来通信的新模式

随着区块链技术的飞速发展&#xff0c;加密“发射台”作为一种新兴的安全通信工具&#xff0c;正逐渐受到关注。本文将从专业角度深入探讨加密“发射台”的概念、原理、应用场景及其未来发展趋势&#xff0c;以期为读者提供有深度和逻辑性的思考。 一、加密“发射台”的概念与…

Chromium 调试指南2024 Windows11篇-准备调试工具(二)

1. 前言 在上篇文章《Chromium 调试指南 2024 &#xff08;一&#xff09;》中&#xff0c;我们简单的概述了下调试的作用。 工欲善其事必先利其器&#xff0c;现在我们开始准备你的调试工具。 2. 准备你的调试工具 这里根据Chromium官方开发指南的推荐使用Visual Studio 2…

360极速浏览器X全新Chromium内核极致顺滑,绿色便携版 v22.3.1002.64

01 软件介绍 360极速浏览器X是一款基于Chromium 95的高级双核浏览器&#xff0c;支持IE内核&#xff0c;并优化了用户体验与性能。包括无广告弹窗&#xff0c;新增的阅读模式&#xff0c;个性化标签页壁纸&#xff0c;以及专业导航功能&#xff0c;旨在提供更快、更高效的浏览…

防火墙技术基础篇:解析防火墙应用层代理概念及功能

防火墙技术基础篇&#xff1a;解析防火墙应用层代理概念及功能 1 应用层代理的概念 应用层代理&#xff08;Application Proxy&#xff09;&#xff1a;防火墙应用层代理是网络安全领域中的一种重要技术&#xff0c;工作在OSI模型的第七层&#xff0c;即应用层。它通过代理服…

初步理解ECC

理解一下公钥加密的概念 公钥加密需要一对钥匙&#xff0c;公钥和私钥&#xff0c;公钥可以公开&#xff0c;而私钥不能泄露。 那就可以用公钥给明文加密 而只有私钥才能进行解密 而要想实现这个过程&#xff0c;就需要满足两个点 1&#xff1a;加密简单易行 2&#xff1a;解…

经常睡不好觉?试试用上华为手环9新升级的睡眠监测功能

睡眠问题是不是经常困扰着你呢&#xff1f;听说&#xff0c;华为手环9的睡眠监测功能升级了&#xff0c;无论是入睡前、睡眠中还是睡醒后&#xff0c;都能够帮助我们改善睡眠&#xff0c;让我们告别糟糕的睡眠质量&#xff01; 睡觉前&#xff0c;打开华为手环9的睡眠模式&…

Linux 操作系统TCP、UDP

1、TCP服务器编写流程 头文件&#xff1a; #include <sys/socket.h> 1.1 创建套接字 函数原型&#xff1a; int socket(int domain, int type, int protocol); 参数&#xff1a; domain: 网域 AF_INET &#xff1a; IPv4 AF_INET6 &a…

RockChip Android13 添加/删除ListPreference方法

概述: 本章将讲述在Android添加或删除ListPreference的几种方法,并以EthernetSettingsActivity为例,添加/删除一项ListPreference: 默认效果图: 添加后效果图: 方法一: 1、全部添加xml 在Activity类中使用addPreferencesFromResource()方法解析XML文件并添加Prefere…