SQLSTATE[HY000]_ General error_ 1366 Incorrect string value_ 'xF0xA7x92xADxEFxBC...' for column 'content' at row 1

wdzsjl 1个月前 (10-10) 阅读数 13 #易优eyoucms

错误信息 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 字符,包括表情符号等特殊字符。这样就可以避免因字符编码问题导致的插入错误。

wx.jpg ywfw.jpg
热门