zoukankan      html  css  js  c++  java
  • 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表情(微信开发用户昵称..)

  • 相关阅读:
    SpringBoot学习
    Matlab立体标定mat转换成Opencv的CvMat
    由lib引发的血案(opencv找不函数问题)
    C# 使用Epplus导出Excel [4]:合并指定行
    C# 使用Epplus导出Excel [3]:合并列连续相同数据
    C# 使用Epplus导出Excel [2]:导出动态列数据
    C# 使用Epplus导出Excel [1]:导出固定列数据
    C# Excel常用控件总结
    C# IsNullOrEmpty与IsNullOrWhiteSpace
    C# 读App.config配置文件[2]: .Net Core框架
  • 原文地址:https://www.cnblogs.com/lhat/p/9967751.html
Copyright © 2011-2022 走看看