Emoji表情符号如何存入mysql数据库中

Emoji表情符号如何存入mysql数据库


今天项目上就碰到这个问题,app端传过来的Emoji表情以utf8编码存入数据库,最后读出来无法显示

经过资料搜查,发现Emoji表情符号为4个字节的字符,而 utf8 字符集只支持1-3个字节的字符,导致无法写入数据库

那么解决办法有两种

1、遍历输入的文本,把四字节长度的字符,修正为自定义的字符替换掉。

2、修改MySQL数据库字符集, 把数据库字符集从utf8 修改为支持1-4 个字节字符的utf8mb4。

实际上第一种的办法工作量太大,并不可取。推荐使用第二种方案,修改数据库字符集。从MySQL 5.5.3版本开始,数据库可支持4个字节的utf8mb4 字符集,一个字符最多可以有4个字节,所以能支持更多的字符集,故能存储Emoji表情符号。从 mysql 5.5.3 之后版本基本可以无缝升级到 utf8mb4 字符集。同时,utf8mb4兼容utf8字符集,utf8 字符的编码、位置、存储在utf8mb4与utf8字符集里一样的,不会对有现有数据带来损坏。

升级方案:

修改数据库字符集character-set-server=utf8mb4 重启数据库生效。

修改database 的字符集为 utf8mb4 alter database dbname character set utf8mb4

修改表的字符集 为utf8mb4 , alter table character set = utf8mb4

附上ios emoji表情库

http://punchdrunker.github.io/iOSEmoji/table_html/bell.html



{{collectdata}}

网友评论0