How to fix double-encoded UTF8 characters (in an utf-8 table)(如何修复双重编码的 UTF8 字符(在 utf-8 表中))
问题描述
之前的 LOAD DATA INFILE
是在假设 CSV 文件是 latin1
编码的情况下运行的.在此导入过程中,多字节字符被解释为两个单个字符,然后(再次)使用 utf-8 进行编码.
A previous LOAD DATA INFILE
was run under the assumption that the CSV file is latin1
-encoded. During this import the multibyte characters were interpreted as two single character and then encoded using utf-8 (again).
这种双重编码产生了像ñ
而不是ñ
这样的异常.
This double-encoding created anomalies like ñ
instead of ñ
.
如何更正这些字符串?
推荐答案
下面的MySQL函数会在双重编码后返回正确的utf8字符串:
The following MySQL function will return the correct utf8 string after double-encoding:
CONVERT(CAST(CONVERT(field USING latin1) AS BINARY) USING utf8)
它可以与 UPDATE
语句一起使用以更正字段:
It can be used with an UPDATE
statement to correct the fields:
UPDATE tablename SET
field = CONVERT(CAST(CONVERT(field USING latin1) AS BINARY) USING utf8);
这篇关于如何修复双重编码的 UTF8 字符(在 utf-8 表中)的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:如何修复双重编码的 UTF8 字符(在 utf-8 表中)


- 如何将 Byte[] 插入 SQL Server VARBINARY 列 2021-01-01
- 导入具有可变标题的 Excel 文件 2021-01-01
- 以一个值为轴心,但将一行上的数据按另一行分组? 2022-01-01
- SQL 临时表问题 2022-01-01
- 如何将 SonarQube 6.7 从 MySQL 迁移到 postgresql 2022-01-01
- 远程 mySQL 连接抛出“无法使用旧的不安全身份验证连接到 MySQL 4.1+"来自 XAMPP 的错误 2022-01-01
- 在SQL中,如何为每个组选择前2行 2021-01-01
- 如何使用 pip 安装 Python MySQLdb 模块? 2021-01-01
- 更改自动增量起始编号? 2021-01-01
- 使用 Oracle PL/SQL developer 生成测试数据 2021-01-01