SpringbootMybatis写数据中⽂变成问号?解决办法背景
有⼀个需求,需要往数据库写⼊数据。但是在写⼊英⽂的时候,没有问题,写⼊中⽂的时候全部变成了问号 ‘?’。问题排查
在最开始的写⼊⽅式是按照从map中读取数据的⽅式写⼊的,怀疑是这种原因导致的数据错误。
经测试,发现,即使使⽤model的⽅式写⼊也会有问题,怀疑是数据库配置除了问题。
根据MyBatis断点跟踪的时候,发现了⼀个异常的地⽅。
具体的SQL如下:
SHOW
springboot中文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/myf
在⽂件中添加或者更改character_set_server=UTF8之后service mysql restart 重启mysql服务
Mac端:
cd /etc
sudo touch myf
sudo vim myf
添加
[mysqld]
character-set-server=utf8
[client]
default-character-set=utf8
[mysql]
default-character-set=utf8
之后重启mysql服务
结果⽐较

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。