加载数据输入文件:无效的 ut8mb4 字符串

LOAD DATA INFILE: Invalid ut8mb4 character string(加载数据输入文件:无效的 ut8mb4 字符串)
本文介绍了加载数据输入文件:无效的 ut8mb4 字符串的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在使用 LOAD DATA INFILE 导入一些大表 (iTunes EPF).

I'm using LOAD DATA INFILE to import some big tables (iTunes EPF).

但是,导入失败并出现以下错误:

However, the import fails with this error:

string(52) "Invalid utf8mb4 character string: 'אל נא תלך'"

表是这样创建的:

CREATE TABLE `song-tmp` (
  `song_id` int(11) NOT NULL DEFAULT '0',
  `name` varchar(1000) DEFAULT NULL,
  `title_version` varchar(1000) DEFAULT NULL,
  `artist_display_name` varchar(1000) DEFAULT NULL,
  PRIMARY KEY (`song_id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4;

这是我正在使用的导入查询:

This is the import query I'm using:

LOAD DATA LOCAL INFILE '/path/to/file' INTO TABLE `song-tmp`
  CHARACTER SET utf8mb4
  FIELDS TERMINATED BY X'01' 
  LINES TERMINATED BY X'020a'
  (@export_date, song_id, name, title_version, @search_terms, @parental_advisory_id, artist_display_name, @collection_display_name, @view_url, @original_release_date, @itunes_release_date, @track_length, @copyright, @p_line, @preview_url, @preview_length)

推荐答案

正如 Rick James 建议的那样,在 LOAD 语句之前运行 SET NAMES utf8mb4; 就可以了.

As Rick James suggested, running SET NAMES utf8mb4; before the LOAD statement did the trick.

这篇关于加载数据输入文件:无效的 ut8mb4 字符串的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

Hibernate reactive No Vert.x context active in aws rds(AWS RDS中的休眠反应性非Vert.x上下文处于活动状态)
Bulk insert with mysql2 and NodeJs throws 500(使用mysql2和NodeJS的大容量插入抛出500)
Flask + PyMySQL giving error no attribute #39;settimeout#39;(FlASK+PyMySQL给出错误,没有属性#39;setTimeout#39;)
auto_increment column for a group of rows?(一组行的AUTO_INCREMENT列?)
Sort by ID DESC(按ID代码排序)
SQL/MySQL: split a quantity value into multiple rows by date(SQL/MySQL:按日期将数量值拆分为多行)