【MySQL】总结:外部txt数据导入MySQL的避坑指南(ERROR code: 3948/2068/1300/1366)

本文主要是介绍【MySQL】总结:外部txt数据导入MySQL的避坑指南(ERROR code: 3948/2068/1300/1366),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

(一)背景:

昨天在导入外部数据(txt文件)到MySQL时成功收获5连错,花了小半天把问题解决,意识到这或许是新手在导入数据时容易出现的问题。因此决定基于报错问题总结导入外部数据时要注意的事项,希望能够帮到MySQL学习的同好们。

(二)环境及语句:

Windows 10;

MySQL Server 8.0.29;

MySQL Workbench 8.0.29;

(三)结论:

我导入txt文件的代码如下:

 语句模板为:

 # 导入外部数据到Monthly_Indicator中load data infile 'txt文件的绝对路径(包含扩展名)'into table 目标表格fields terminated by '\t' # 我的txt文件分割方式为制表符,制表符符号为'\t',因此指定MySQL导入时的分割方式为'\t';ignore 1 lines;# 我的txt文件第一行是字段名,导入时应忽略字段名,故指定MySQL忽略第一行;

需要注意的事项为:

  1. 请检查你的local_infile状态,确保它是打开的;

  2. 请将txt文件编码格式改成utf-8;

  3. 请确保外部文件对应字段的数据类型和MySQL中的一致;

  4. 请将txt文件移至MySQL Server路径的Uploads文件夹中:

(四)避坑总结:

1. 请检查你的local_infile状态:

  • local_infile是全局系统变量,功能是决定能否使用load data local infile的命令。
  • MySQL 8.0.29 中,local_infile的默认状态是关闭的。
  • 因此,如果想利用load data local infile录入外部数据,请先将其打开。
  • 未打开local_infile的报错为:

       ERROR: 3948, Loading local data is disabled - this must be enabled on both the client and server sides.

打开local_infile的方式如下:

  • 打开MySQL Server 8.0 Command Line Clinet:


  • 检查local_infile状态:

    输入如下语句

    mysql > show variables like 'local_infile';
    # 输入上述语句就能够检查local_infile状态。
    (mysql > 是打开客户端后自动显示的,所以不用重复输入)

     

    可以看到local_infile的Value为"OFF“,此时的local_infile是关闭的,无法通过load data local infile导入外部数据。

  • 打开local_infile开关:

    (1)输入如下语句

set global local_infile = 1;

 

 (2)再次检查local_infile状态:

可以看见此时的local_infile已经打开了。

2. 请将txt文件编码格式改成utf-8:

  • MySQL的默认编码是utf8;
  • txt文件的默认编码是ANSI;
  • 如果不改txt文件编码就直接导入MySQL,则会读取失败;
  • 不改txt文件编码的报错为:

      Error Code: 1300. Invalid utf8mb4 character string:''

改变txt的编码,只需要打开目标文件,点击【另存为】,在弹出界面的右下角就能够选择编码格式,我们选择UTF-8就好了。

 3. 请确保外部文件对应字段的数据类型和MySQL中的一致:

  • 导入数据前,我们会现在MySQL中定义表,并为字段设置数据类型;
  • 如果txt文件对应的字段数据类型和MySQL对应字段数据类型不一致,就可能会发生报错;
  • 例子MySQL中字段ranking设置为整型,而txt中ranking却是字符' - '。那么,在将txt录入MySQL时,ranking数据的录入就会因为数据类型不符而失败;
  • 数据类型不匹配时的报错为:

      Error Code: 1366. Incorrect integer value: '- ' for column 'ranking' at row 1

      (仅展示一种情况,实际报错情况不仅限于这一种)

4. 请将txt文件移至MySQL Server路径的Uploads文件夹中:

  • 未将txt文件移至Uploads文件夹的报错为:

      Error Code: 2068. LOAD DATA LOCAL INFILE file request rejected due to restrictions on access.

 由于不把txt文件移到Uploasd文件夹下会报错,所以我们应该将txt移进去,方法如下:

(1)找到你的MySQL Server路径:

如果是自定义路径安装的,指定的路径就是MySQL Server8.0的路径;如果忘记了路径在哪里,可以打开 MySQL Server 8.0 Command Line Clinet,输入以下语句找回:

show variables like '%basedir%';

 

(2)将txt文件移到MySQL Server8.0\Uploads中: 

双击MySQL Server8.0后,进入Uploads文件夹。

 将txt文件移到这里就好了。

 

这篇关于【MySQL】总结:外部txt数据导入MySQL的避坑指南(ERROR code: 3948/2068/1300/1366)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/364825

相关文章

使用Python开发一个Ditto剪贴板数据导出工具

《使用Python开发一个Ditto剪贴板数据导出工具》在日常工作中,我们经常需要处理大量的剪贴板数据,下面将介绍如何使用Python的wxPython库开发一个图形化工具,实现从Ditto数据库中读... 目录前言运行结果项目需求分析技术选型核心功能实现1. Ditto数据库结构分析2. 数据库自动定位3

pandas数据的合并concat()和merge()方式

《pandas数据的合并concat()和merge()方式》Pandas中concat沿轴合并数据框(行或列),merge基于键连接(内/外/左/右),concat用于纵向或横向拼接,merge用于... 目录concat() 轴向连接合并(1) join='outer',axis=0(2)join='o

批量导入txt数据到的redis过程

《批量导入txt数据到的redis过程》用户通过将Redis命令逐行写入txt文件,利用管道模式运行客户端,成功执行批量删除以Product*匹配的Key操作,提高了数据清理效率... 目录批量导入txt数据到Redisjs把redis命令按一条 一行写到txt中管道命令运行redis客户端成功了批量删除k

破茧 JDBC:MyBatis 在 Spring Boot 中的轻量实践指南

《破茧JDBC:MyBatis在SpringBoot中的轻量实践指南》MyBatis是持久层框架,简化JDBC开发,通过接口+XML/注解实现数据访问,动态代理生成实现类,支持增删改查及参数... 目录一、什么是 MyBATis二、 MyBatis 入门2.1、创建项目2.2、配置数据库连接字符串2.3、入

MySQL中EXISTS与IN用法使用与对比分析

《MySQL中EXISTS与IN用法使用与对比分析》在MySQL中,EXISTS和IN都用于子查询中根据另一个查询的结果来过滤主查询的记录,本文将基于工作原理、效率和应用场景进行全面对比... 目录一、基本用法详解1. IN 运算符2. EXISTS 运算符二、EXISTS 与 IN 的选择策略三、性能对比

MySQL常用字符串函数示例和场景介绍

《MySQL常用字符串函数示例和场景介绍》MySQL提供了丰富的字符串函数帮助我们高效地对字符串进行处理、转换和分析,本文我将全面且深入地介绍MySQL常用的字符串函数,并结合具体示例和场景,帮你熟练... 目录一、字符串函数概述1.1 字符串函数的作用1.2 字符串函数分类二、字符串长度与统计函数2.1

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

Apache Ignite 与 Spring Boot 集成详细指南

《ApacheIgnite与SpringBoot集成详细指南》ApacheIgnite官方指南详解如何通过SpringBootStarter扩展实现自动配置,支持厚/轻客户端模式,简化Ign... 目录 一、背景:为什么需要这个集成? 二、两种集成方式(对应两种客户端模型) 三、方式一:自动配置 Thick

SQL Server跟踪自动统计信息更新实战指南

《SQLServer跟踪自动统计信息更新实战指南》本文详解SQLServer自动统计信息更新的跟踪方法,推荐使用扩展事件实时捕获更新操作及详细信息,同时结合系统视图快速检查统计信息状态,重点强调修... 目录SQL Server 如何跟踪自动统计信息更新:深入解析与实战指南 核心跟踪方法1️⃣ 利用系统目录

使用IDEA部署Docker应用指南分享

《使用IDEA部署Docker应用指南分享》本文介绍了使用IDEA部署Docker应用的四步流程:创建Dockerfile、配置IDEADocker连接、设置运行调试环境、构建运行镜像,并强调需准备本... 目录一、创建 dockerfile 配置文件二、配置 IDEA 的 Docker 连接三、配置 Do