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. 修改数据库字符集

  1. 登录 MySQL 数据库: 使用命令行工具登录 MySQL 数据库。

    sh
     
    mysql -u your_username -p
  2. 选择数据库: 选择对应的数据库。

    sql
     
    USE your_database_name;
  3. 修改数据库字符集: 将数据库的字符集修改为 utf8mb4

    sql
     
    ALTER DATABASE your_database_name CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;

3. 修改数据表字段类型

  1. 修改数据表字段类型: 将数据表的 content 字段类型设置为 LONGTEXT,并设置字符集为 utf8mb4

    sql
     
    ALTER TABLE your_table_name MODIFY COLUMN content LONGTEXT CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;

4. 修改 MySQL 配置文件

  1. 打开 MySQL 配置文件: 打开 MySQL 的配置文件 my.cnf 或 my.ini。通常该文件位于 /etc/mysql/my.cnf 或 /etc/my.cnf

  2. 修改配置项: 确认以下配置项已调整为合适的值:

    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
  3. 保存并重载配置: 保存配置文件并重载 MySQL 配置。

    sh
     
    sudo systemctl reload mysql

5. 重启 MySQL 服务

  1. 重启 MySQL 服务: 重启 MySQL 服务以使更改生效。

    sh
     
    sudo systemctl restart mysql

宝塔环境下的配置

如果您使用的是宝塔环境,可以按照以下步骤操作:

  1. 打开宝塔面板: 登录宝塔面板控制台。

  2. 找到 MySQL 配置文件: 在宝塔面板中找到 MySQL 的配置文件 my.cnf,通常位于 /www/server/mysql/my.cnf

  3. 修改配置项: 在配置文件中添加或修改以下配置项:

    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
  4. 保存并重启 MySQL 服务: 保存配置文件并重启 MySQL 服务。

    sh
     
    sudo systemctl restart mysql

综合检查

  1. 检查所有配置项: 确认所有相关配置项都已调整为合适的值。

  2. 测试上传: 重新尝试插入包含表情符号的数据,检查是否仍然出现错误。

示例配置

以下是完整的示例配置:

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

通过上述步骤,可以确保数据库和数据表的字符集都已调整为 utf8mb4,从而支持所有 Unicode 字符,包括表情符号等特殊字符。这样就可以避免因字符编码问题导致的插入错误。

posted @   黄文Rex  阅读(184)  评论(0编辑  收藏  举报
(评论功能已被禁用)
相关博文:
阅读排行:
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
点击右上角即可分享
微信分享提示