mysql 5.7数据库支持emoji符号可是程序总算报错Incorrect string value: '\xF0\x9F\x98\x84\xF0\x9F...' for column ...

1.线上碰到个问题,端上切换搜狗输入法后,原来限制的表情符号还能输入。数据库使用的是5.7.22版本的,刚开始觉得数据库不支持表情符号致使的,可是看了线上的数据库以及字段,都是支持的。java

 

show variables like '%character%';mysql

 

show full columns from driver_reward_record;sql

 

 

 

 

直接使用sql语句经过navicate 客户端,也是能够插入成功的。可是在程序里面 死活插入不进去,这就郁闷了。数据库

 

     看了下mysql的 mysql-connector-java 版本是5.1.34,大于5.1.13 也是没问题的。数据库、表、字段 都是utf8mb4的,也是正常的。而后怀疑是项目 过滤器编码的问题,可是在项目里面写死而后启动项目,仍然提示插入错误:Incorrect string value: '\xF0\x9F\x98\x84\xF0\x9F...' for column ...     这就郁闷了啊~~ui

 

  而后网上各类找解决方案,最后总算找到了。参考了编码

  https://blog.csdn.net/KillerAwp/article/details/82356042 这篇文章。 最后的解决方案:url

 

修改应用链接字符串(druid):
<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource" init-method="init" destroy-method="close">
    <property name="driverClassName" value="${jdbc-driver}"/>
    <property name="url" value="${jdbc-url}"/>
    <property name="username" value="${jdbc-user}"/>
    <property name="password" value="${jdbc-password}"/>
    <property name="filters" value="stat"/>
    <property name="maxActive" value="20"/>
    <property name="initialSize" value="1"/>
    <property name="maxWait" value="60000"/>
    <property name="minIdle" value="1"/>
    <property name="timeBetweenEvictionRunsMillis" value="3000"/>
    <property name="minEvictableIdleTimeMillis" value="300000"/>
    <property name="validationQuery" value="SELECT 'x'"/>
    <property name="testWhileIdle" value="true"/>
    <property name="testOnBorrow" value="false"/>
    <property name="testOnReturn" value="false"/>
    <property name="poolPreparedStatements" value="true"/>
    <property name="maxPoolPreparedStatementPerConnectionSize" value="20"/>
    <property name="connectionInitSqls" value="set names utf8mb4;"/>  // 必须添加
</bean>

spa

 

总算解决了。.net

相关文章
相关标签/搜索