SQLSTATE[HY000]_ General error_ 1366 Incorrect string value_ 'xF0xA7x92xADxEFxBC...' for column 'content' at row 1
错误信息 General error: 1366 Incorrect string value: '\xF0\x9F\x98' for column 'content'
表示在插入数据时,content
字段的内容包含了一些不支持的特殊字符(如表情符号),导致插入失败。这是因为 MySQL 的 utf8
编码不支持某些四字节的 Unicode 字符,而 utf8mb4
编码则支持所有 Unicode 字符。
解决方案
1. 升级 MySQL 版本
确保您的 MySQL 版本至少为 5.5 或更高版本,以支持 utf8mb4
编码。
2. 修改数据库字符集
-
登录 MySQL 数据库: 使用命令行工具登录 MySQL 数据库。
shmysql -u your_username -p
-
选择数据库: 选择对应的数据库。
sqlUSE your_database_name;
-
修改数据库字符集: 将数据库的字符集修改为
utf8mb4
。sqlALTER DATABASE your_database_name CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;
3. 修改数据表字段类型
-
修改数据表字段类型: 将数据表的
content
字段类型设置为LONGTEXT
,并设置字符集为utf8mb4
。sqlALTER TABLE your_table_name MODIFY COLUMN content LONGTEXT CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;
4. 修改 MySQL 配置文件
-
打开 MySQL 配置文件: 打开 MySQL 的配置文件
my.cnf
或my.ini
。通常该文件位于/etc/mysql/my.cnf
或/etc/my.cnf
。 -
修改配置项: 确认以下配置项已调整为合适的值:
ini[client] default-character-set=utf8mb4 [mysqld] character-set-server=utf8mb4 collation-server=utf8mb4_unicode_ci init-connect='SET NAMES utf8mb4' skip-character-set-client-handshake=true [mysql] default-character-set=utf8mb4
-
保存并重载配置: 保存配置文件并重载 MySQL 配置。
shsudo systemctl reload mysql
5. 重启 MySQL 服务
-
重启 MySQL 服务: 重启 MySQL 服务以使更改生效。
shsudo systemctl restart mysql
宝塔环境下的配置
如果您使用的是宝塔环境,可以按照以下步骤操作:
-
打开宝塔面板: 登录宝塔面板控制台。
-
找到 MySQL 配置文件: 在宝塔面板中找到 MySQL 的配置文件
my.cnf
,通常位于/www/server/mysql/my.cnf
。 -
修改配置项: 在配置文件中添加或修改以下配置项:
ini[client] default-character-set=utf8mb4 [mysqld] character-set-server=utf8mb4 collation-server=utf8mb4_unicode_ci init-connect='SET NAMES utf8mb4' skip-character-set-client-handshake=true [mysql] default-character-set=utf8mb4
-
保存并重启 MySQL 服务: 保存配置文件并重启 MySQL 服务。
shsudo systemctl restart mysql
综合检查
-
检查所有配置项: 确认所有相关配置项都已调整为合适的值。
-
测试上传: 重新尝试插入包含表情符号的数据,检查是否仍然出现错误。
示例配置
以下是完整的示例配置:
MySQL 配置文件 my.cnf
[client] default-character-set=utf8mb4 [mysqld] character-set-server=utf8mb4 collation-server=utf8mb4_unicode_ci init-connect='SET NAMES utf8mb4' skip-character-set-client-handshake=true [mysql] default-character-set=utf8mb4
通过上述步骤,可以确保数据库和数据表的字符集都已调整为 utf8mb4
,从而支持所有 Unicode 字符,包括表情符号等特殊字符。这样就可以避免因字符编码问题导致的插入错误。