mysql 5.7數據庫支持emoji符號但是程序總算報錯Incorrect string value: '\xF0\x9F\x98\x84\xF0\x9F...' for column ...


1.線上碰到個問題,端上切換搜狗輸入法后,原來限制的表情符號還能輸入。數據庫使用的是5.7.22版本的,剛開始以為數據庫不支持表情符號導致的,但是看了線上的數據庫以及字段,都是支持的。

 

show variables like '%character%';

 

show full columns from driver_reward_record;

 

 

 

 

直接使用sql語句通過navicate 客戶端,也是可以插入成功的。但是在程序里面 死活插入不進去,這就郁悶了。

 

     看了下mysql的 mysql-connector-java 版本是5.1.34,大於5.1.13 也是沒問題的。數據庫、表、字段 都是utf8mb4的,也是正常的。然后懷疑是項目 過濾器編碼的問題,但是在項目里面寫死然后啟動項目,仍然提示插入錯誤:Incorrect string value: '\xF0\x9F\x98\x84\xF0\x9F...' for column ...     這就郁悶了啊~~

 

  然后網上各種找解決方案,最后總算找到了。參考了

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

 

修改應用連接字符串(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>

 

總算解決了。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM