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

COS、CDN
wdzsjl 3个月前 (10-10) 阅读数 100 #WordPress

错误信息 SQLSTATE[HY000]: General error: 1366 Incorrect string value: '\xF0\x9F...' for column 'content' at row 1 表明插入的数据包含不正确的字符或编码问题。具体原因可能包括:

  1. 字符集不匹配:数据库表的字符集与应用中使用的字符集不一致。
  2. 字段类型不支持某些字符VARCHAR 或 TEXT 类型字段可能不支持某些特殊字符。
  3. 客户端连接字符集设置不正确:客户端连接数据库时的字符集设置不正确。

解决办法

1. 检查数据库表的字符集

  1. 查询数据库表的字符集

    • 使用 SQL 查询语句查看表的字符集:
      sql
       
      SHOW CREATE TABLE your_table_name;
  2. 确认字符集

    • 确认表的字符集是否为 utf8mb4,因为 utf8mb4 支持所有 Unicode 字符。

2. 修改数据库表的字符集

  1. 修改表的字符集

    • 如果表的字符集不是 utf8mb4,可以修改为 utf8mb4
      sql
       
      ALTER DATABASE your_database_name CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci; ALTER TABLE your_table_name CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
  2. 修改字段的字符集

    • 如果只是特定字段有问题,可以单独修改字段的字符集:
      sql
       
      ALTER TABLE your_table_name MODIFY COLUMN content TEXT CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;

3. 检查客户端连接字符集

  1. 确认客户端连接字符集

    • 确认客户端连接数据库时的字符集设置是否正确。
    • 例如,在 PHP 中,可以设置连接字符集:
      php
       
      $pdo = new PDO("mysql:host=localhost;dbname=your_database_name;charset=utf8mb4", "username", "password");
  2. 确认 MySQL 客户端设置

    • 如果使用命令行工具连接 MySQL,可以设置字符集:
      sql
       
      mysql -u username -p --default-character-set=utf8mb4 your_database_name

4. 检查插入数据的编码

  1. 检查插入数据的编码

    • 确认插入的数据是否使用了正确的编码。
    • 可以使用 PHP 的 mb_check_encoding 函数检查字符串编码:
      php
       
      $content = "...\xF0\x9F..."; // 插入的数据 if (!mb_check_encoding($content, 'UTF-8')) { // 数据编码不正确 echo "数据编码不正确"; }
  2. 转换数据编码

    • 如果数据编码不正确,可以尝试转换编码:
      php
       
      $content = mb_convert_encoding($content, 'UTF-8', 'auto');

5. 检查数据库配置

  1. 检查 MySQL 配置文件

    • 确认 MySQL 服务器的配置文件 (my.cnf 或 my.ini) 中的默认字符集设置是否正确:
      ini
       
      [mysqld] character-set-server=utf8mb4 collation-server=utf8mb4_unicode_ci
  2. 检查 PHP 配置文件

    • 确认 PHP 的配置文件 (php.ini) 中的默认字符集设置是否正确:
      ini
       
      default_charset = "UTF-8"

实际操作步骤

1. 检查数据库表的字符集

  1. 查询数据库表的字符集

    sql
     
    SHOW CREATE TABLE your_table_name;
  2. 确认字符集

    • 确认表的字符集是否为 utf8mb4

2. 修改数据库表的字符集

  1. 修改表的字符集

    sql
     
    ALTER DATABASE your_database_name CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci; ALTER TABLE your_table_name CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
  2. 修改字段的字符集

    sql
     
    ALTER TABLE your_table_name MODIFY COLUMN content TEXT CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;

3. 检查客户端连接字符集

  1. 确认客户端连接字符集

    • 在 PHP 中设置连接字符集:
      php
       
      $pdo = new PDO("mysql:host=localhost;dbname=your_database_name;charset=utf8mb4", "username", "password");
  2. 确认 MySQL 客户端设置

    sql
     
    mysql -u username -p --default-character-set=utf8mb4 your_database_name

4. 检查插入数据的编码

  1. 检查插入数据的编码

    php
     
    $content = "...\xF0\x9F..."; // 插入的数据 if (!mb_check_encoding($content, 'UTF-8')) { // 数据编码不正确 echo "数据编码不正确"; }
  2. 转换数据编码

    php
     
    $content = mb_convert_encoding($content, 'UTF-8', 'auto');

5. 检查数据库配置

  1. 检查 MySQL 配置文件

    • 确认 MySQL 服务器的配置文件 (my.cnf 或 my.ini) 中的默认字符集设置是否正确:
      ini
       
      [mysqld] character-set-server=utf8mb4 collation-server=utf8mb4_unicode_ci
  2. 检查 PHP 配置文件

    • 确认 PHP 的配置文件 (php.ini) 中的默认字符集设置是否正确:
      ini
       
      default_charset = "UTF-8"

总结

通过上述步骤,你可以解决由于字符集不匹配或编码问题导致的错误。如果还有其他问题或需要进一步的帮助,请随时告知。

COS、CDN
热门