Golang MySQL 1366 incorrect string value 错误

Golang MySQL 1366 incorrect string value error

我正在向我的数据库中插入字符串,但收到无效字符串字节序列的 MySQL 1366 错误。

2016/11/04 13:33:40 Error 1366: Incorrect string value: '\x89PNG\x0D\x0A...' for column 'text' at row 1
2016/11/04 13:33:56 Error 1366: Incorrect string value: '\xB6\xEB\xE4\x0B\x92\xEE...' for column 'text' at row 1
2016/11/04 13:33:56 Error 1366: Incorrect string value: '\xFF\xD8\xFF\xE0\x00\x10...' for column 'text' at row 1
2016/11/04 13:34:35 Error 1366: Incorrect string value: '\x9C]\x91\xD1k\xC2...' for column 'text' at row 1

我的 MySQL 配置设置为 utf8mb4,如下所示:

mysql> SHOW VARIABLES LIKE 'character_set%';
+--------------------------+----------------------------+
| Variable_name            | Value                      |
+--------------------------+----------------------------+
| character_set_client     | utf8mb4                    |
| character_set_connection | utf8mb4                    |
| character_set_database   | utf8mb4                    |
| character_set_filesystem | binary                     |
| character_set_results    | utf8mb4                    |
| character_set_server     | utf8mb4                    |
| character_set_system     | utf8                       |
| character_sets_dir       | /usr/share/mysql/charsets/ |
+--------------------------+----------------------------+
8 rows in set (0.00 sec)

我的数据库连接池是这样的:

db, err = sql.Open("mysql", config.User+":"+config.Password+"@tcp("+config.Host+")/"+config.Database)
if err != nil {
    log.Fatal(err)
}

db.Exec("SET NAMES 'utf8mb4'; SET CHARACTER SET utf8mb4;")

我还缺少什么?

这些不是有效的 UTF-8 字符串;这些是二进制数据(第一个是 PNG 文件!)。您需要将它们存储在一个真正的二进制列中,因为 MySQL 确实执行特定于 UTF-8 的操作,例如大小写折叠和语言整理。 (Go 不会对字符串强制执行 UTF-8 编码,因此 Go 不会抱怨。Go 仅使用 UTF-8 对字符串文字进行编码,但是 \x 转义序列会覆盖它。当然,range, []rune 转换,各种包假设字符串是 UTF-8。)

您可以使用 utf8.ValidString().

检查字符串是否为有效序列

对包含图像的列使用 BLOB(可能 MEDIUMBLOB)数据类型。使用 TEXT 会导致检查编码。 PNG 不包含正确编码的 utf8 字符,因此出现错误。

您对 utf8mb4 的其余用法可能没问题。