• MySQL保存 emoji 表情(微信昵称表情)


    问题分析

    在微信开发过程中,总是会遇到带有emoji表情昵称的微信用户无法自动登录的问题。
    后台代码抛出类似下面的异常信息。

    java.sql.SQLException: Incorrect string value: 'xF0x9Fx92x94' for colum n 'name' at row 1 
    at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:1073) 
    at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3593) 
    at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3525) 
    at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:1986) 
    at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2140) 
    at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2620) 
    at com.mysql.jdbc.StatementImpl.executeUpdate(StatementImpl.java:1662) 
    at com.mysql.jdbc.StatementImpl.executeUpdate(StatementImpl.java:1581)
    

    原来emoji表情是占4个字节的,但是在MySQL中UTF-8字符只是占3个字节,这就导致MySQL数据库无法保存emoji表情了。

    解决方法

    既然知道了原因,那么解决方法也就产生了。
    只要让MySQL的字符占4个字节就成了。恰好MySQL5.5.3 以后的版本都有 utf8mb4 这种字符集,它每个字符占4个字节,满足保存emoji表情的需要。
    现在目标是将MySQL数据库有原来的字符集修改为 utf8mb4。

    1. 修改数据库、表、列的字符集

    ALTER DATABASE database_name CHARACTER SET = utf8mb4 COLLATE = utf8mb4_unicode_ci;
    ALTER TABLE table_name CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
    ALTER TABLE table_name CHANGE column_name VARCHAR(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
    

    2. 修改MySQL配置文件 my.cnf(windows下是 my.ini)

    [client]    
    default-character-set = utf8mb4    
    [mysql]    
    default-character-set = utf8mb4    
    [mysqld]    
    character-set-client-handshake = FALSE    
    character-set-server = utf8mb4    
    collation-server = utf8mb4_unicode_ci    
    init_connect='SET NAMES utf8mb4'    
    

    注意: 如果后台代码使用了 mysql-connector-x.x.x.jar ,那么mysql-connector的版本必须高于 5.1.13 ,否则不支持 utf8mb4。


    参考这篇博客 mysql保存emoji表情(微信开发用户昵称..)

  • 相关阅读:
    不依赖OFFICE组件实现带图片的EXCEL导出
    关于安装SQL的错误
    Web开发学习点滴(持续更新)
    窗体间传值汇总
    沈阳.NET俱乐部MSN群开张了。。。
    VoIP协议标准浅析
    名词解释
    创建和运行一个解决方案
    400电话为什么叫免费电话?
    XPO基础简化的属性语法:
  • 原文地址:https://www.cnblogs.com/lhat/p/9967751.html
Copyright © 2020-2023  润新知