背景
有一個需求,需要往數據庫寫入數據。但是在寫入英文的時候,沒有問題,寫入中文的時候全部變成了問號 ‘?’。
問題排查
在最開始的寫入方式是按照從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服務