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>
總算解決了。
