mysql 插入_解决mysql插入表情出现异常问题

用wangEditor.js插件编写包含表情保存到mysql的时候出现报错:

76c197899159fd4e5d39e2dabcd64561.png
内容中增加表情包

Cause: java.sql.SQLException: Incorrect string value: 'xF0x9Fx98x86<b...' for column 'content' at row 1

解决方法之一:

因为一般情况下是公司内部用的管理系统,基本上不会用到表情 可以去掉 在wangEditor.js默认菜单配置中去掉emoticon元素就可以了

// 默认菜单配置 修改前
        menus: ['head', 'bold', 'italic', 'underline', 'strikeThrough', 'foreColor', 'backColor', 'link', 'list', 'justify', 'quote', 'emoticon', 'image', 'table', 'video', 'code', 'undo', 'redo'],
//  默认菜单配置 修改后
        menus: ['head', 'bold', 'italic', 'underline', 'strikeThrough', 'foreColor', 'backColor', 'link', 'list', 'justify', 'quote', 'image', 'table', 'video', 'code', 'undo', 'redo'],

解决方法之二:

更改以下 mysql配置文件 并重启mysql

[mysqld]
collation-server=utf8mb4_general_ci
character_set_server=utf8mb4
alter table notice character set utf8mb4;

原因: MySQL的utf8编码最多3个字节,Emoji表情或者某些特殊字符是4个字节,所以数据插入不了,需要修改编码。

在MySQL 的“utf8”实际上不是真正的 UTF-8。

“utf8”只支持每个字符最多三个字节,而真正的 UTF-8 是每个字符最多四个字节。

MySQL 一直没有修复这个 bug,他们在 2010 年发布了一个叫作“utf8mb4”的字符集,绕过了这个问题。

重启mysq只能对之后的生效 那之前的怎么办呢?

修改表的编码

alter table 表名  character set utf8mb4;

修改表中字段的编码

ALTER TABLE 表名
MODIFY COLUMN 字段  字段类型 CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL COMMENT '内容';

如果出现:Unknown collation: 'utf8mb4_0900_ai_ci' 问题 可能是mysql版本过低 用

ALTER TABLE 表名
MODIFY COLUMN 字段   字段类型 CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL COMMENT '内容'

wangEditor.js插件地址

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值