SQLSTATE[HY000]_ General error_ 1366 Incorrect string value_ 'xF0xA7x92xADxEFxBC...' for col
错误信息 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 字符,包括表情符号等特殊字符。这样就可以避免因字符编码问题导致的插入错误。
- 易优cms搜索结果页如何统计关键词文章数量
- 网站源码安装后访问首页,页面错乱的处理方法
- pbootcms模板如何做好防护
- PBOOTCMS中新增并开启手机端模板,以便为用户提供更好的移动设备浏览体验
- Pbootcms留言“提交成功”的提示语修改(1)
- SQLSTATE[HY000] [1045] Access denied for user 'cs2021'@'localhost' (using passwo
- 易优cms数据表或视图不存在,请联系技术处理。
- PbootCMS全站模板date时间标签/时间格式常见的8种调用方式
- pbootcms网站后台登录提示:”登录失败:数据库目录写入权限不足!“
- ZBlog网站自定义单页_支持动态和静态页面生成
- imagecreatefrompng(): gd-png: libpng warning: iCCP: known incorrect sRGB profile
- 易优CMS文章内容页如何获取上一篇下一篇
- 易优CMS网站插件:会员邀请插件介绍
- 错误内容:You have an error in your SQL syntax; check the manual that corresponds to your MySQL server ve
- 易优cms网站后台登录不上
- 类型错误: implode(): Argument #1 ($pieces) must be of type array, string given
- 易优cms中英文版如何分开调用不同模板?
- 易优CMS资源文件加载设置与调用标签
- 迅睿CMS网站自定义搜索URL参数
- 升级完后网站提示500错误怎么办