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

2024-06-04 9222阅读

【mysql】mysql导入导出数据详解 第1张

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

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

🏆 作者简介:景天科技苑

🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,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文件的方法。它允许您将查询结果保存到指定的文件路径中,以便进行后续处理或备份。

          使用案例:

          【mysql】mysql导入导出数据详解 第2张

          我们有一个名为"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

          【mysql】mysql导入导出数据详解 第3张

          【1】分析原因

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

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

          SHOW VARIABLES LIKE "secure_file_priv";
          

          mysql8.0默认目录是/var/lib/mysql-files/

          【mysql】mysql导入导出数据详解 第4张

          可以看到,本地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生效。

          【mysql】mysql导入导出数据详解 第5张

          重启数据库

          systemctl restart mysqld.service
          

          【mysql】mysql导入导出数据详解 第6张

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

          导出到/data/目录报权限不足

          【mysql】mysql导入导出数据详解 第7张

          导出到tmp/目录成功

          【mysql】mysql导入导出数据详解 第8张

          【mysql】mysql导入导出数据详解 第9张

          下载到本地打开

          【mysql】mysql导入导出数据详解 第10张

          (二)使用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@  
          

          二、导入数据

          (一)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改一下

          【mysql】mysql导入导出数据详解 第11张

          (二)执行导入

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

          【mysql】mysql导入导出数据详解 第12张

          查看数据库,导入成功

          【mysql】mysql导入导出数据详解 第13张


    免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们,邮箱:ciyunidc@ciyunshuju.com。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!

    目录[+]