Springboot Mybatis 寫數據中文變成問號 ?解決辦法

背景

有一個需求,需要往數據庫寫入數據。但是在寫入英文的時候,沒有問題,寫入中文的時候全部變成了問號 ‘?’。

問題排查

在最開始的寫入方式是按照從map中讀取數據的方式寫入的,懷疑是這種原因導致的數據錯誤。
經測試,發現,即使使用model的方式寫入也會有問題,懷疑是數據庫配置除了問題。

根據MyBatis斷點跟蹤的時候,發現了一個異常的地方。
具體的SQL如下:

SHOW 
    VARIABLES 
WHERE
    Variable_name = 'language' 
    OR Variable_name = 'net_write_timeout' 
    OR Variable_name = 'interactive_timeout' 
    OR Variable_name = 'wait_timeout' 
    OR Variable_name = 'character_set_client' 
    OR Variable_name = 'character_set_connection' 
    OR Variable_name = 'character_set' 
    OR Variable_name = 'character_set_server' 
    OR Variable_name = 'tx_isolation' 
    OR Variable_name = 'transaction_isolation' 
    OR Variable_name = 'character_set_results' 
    OR Variable_name = 'timezone' 
    OR Variable_name = 'time_zone' 
    OR Variable_name = 'system_time_zone' 
    OR Variable_name = 'lower_case_table_names' 
    OR Variable_name = 'max_allowed_packet' 
    OR Variable_name = 'net_buffer_length' 
    OR Variable_name = 'sql_mode' 
    OR Variable_name = 'query_cache_type' 
    OR Variable_name = 'query_cache_size' 
    OR Variable_name = 'license' 
    OR Variable_name = 'init_connect'

發現其中有一個字段的結果爲:

character_set_server: latin1

其他的關於字符串相關的都是utf8的。

解決方案

!!! 以下操作均需要root權限;

更改本機和服務器的相關參數的配置。

方法一:

使用set character_set_server=utf8
結果不生效,因爲這種操作只是對當前有效的。

方法二:

更改默認配置文件
服務器端:
vim /etc/my.cnf
在文件中添加或者更改character_set_server=UTF8
之後service mysql restart 重啓mysql服務

Mac端:

cd /etc 
sudo touch my.cnf
sudo vim my.cnf
添加
[mysqld]
character-set-server=utf8

[client]
default-character-set=utf8

[mysql]
default-character-set=utf8

之後重啓mysql服務

結果比較

效果圖 前後對比

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章