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