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表情(微信开发用户昵称..)

  • 相关阅读:
    微信自动回复
    pyqt5生成的APP制作DMG
    win10 安装MySQL过程和遇到的坑
    CentOS7 虚拟机设置文件共享 VMWareTools安装遇到的坑
    阿里云配置ssl证书服务遇到的几个问题和解决方法
    Linux基于libmemcached,php扩展memcached的安装
    PHP框架CodeIgniter--URL去除index.php
    javascript新窗口打开链接window.open()被阻拦的解决办法
    Centos6.5源码编译安装nginx
    MySQL批量修改数据库的字符集
  • 原文地址:https://www.cnblogs.com/lhat/p/9967751.html
Copyright © 2011-2022 走看看