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 字符,包括表情符号等特殊字符。这样就可以避免因字符编码问题导致的插入错误。
- 请问如何处理升级为香港主机后网站无法访问的问题
- 防火墙设置与云服务器80端口访问限制
- 解决远程登录服务器失败及重启后仍无法连接的问题
- 远程访问故障排除 - 解决无法登录虚拟主机和数据库的问题
- 解析与绑定完成后网站仍无法正常访问的排查步骤及解决方案
- 请问如何在ASP页面中判断客户端浏览器是否为移动设备,并进行相应的跳转?
- 输入网站后台密码时显示不对,如何解决?
- 选择合适工具,掌握静态网站模板修改方法
- 静态网站上传后如何安全有效地进行修改,确保不影响网站的正常运行?
- 请问如何修改网站图片源代码
- 网站admin密码忘记了怎么办
- 如何解决PbootCMS网站后台推送文章到百度时的“site error”错误?
- 迅睿CMS网站用户投稿如何取消验证码
- 宝塔面板提示不是安全连接或私密连接,如何解决?
- 网站提示429 Too Many Requests:用户发送了太多请求怎么办
- 易优cms搜索结果页如何统计关键词文章数量
- 网站源码安装后访问首页,页面错乱的处理方法
- pbootcms模板如何做好防护
- 重置网站后台管理员账号密码
- 升级完后网站提示500错误怎么办
- pbootcms如何设置发布内容不自动提取缩略图(1)
- 百度网址安全中心提醒您:该页面可能存在违法信息!如何处理?
- 易优cms数据表或视图不存在,请联系技术处理。
- Pbootcms留言“提交成功”的提示语修改(1)
- PBOOTCMS中新增并开启手机端模板,以便为用户提供更好的移动设备浏览体验
- imagecreatefrompng(): gd-png: libpng warning: iCCP: known incorrect sRGB profile
- 易优CMS文章内容页如何获取上一篇下一篇
- PbootCMS全站模板date时间标签/时间格式常见的8种调用方式
- pbootcms网站后台登录提示:”登录失败:数据库目录写入权限不足!“
- Nginx 启动/停止 / 首页显示 / 安装 / 卸载