系统中文保存后显示问号该如何解决(java+Springboot)_java springboot 打印中文的日志怎么都是问号

四个步骤逐步排查:

1、先连接mysql 查看对应的表存储的是否是中文

连接进入查看数据库也存储的是???,那么也就是不是显示问题了。

2、系统是否是设置了正确的支付编码:

首先通过命令 locale 查看系统字符编码
在这里插入图片描述

系统是默认的字符编码,我们可以设置下,然后可以通过下面命令查看系统支持哪些字符编码:

locale -am|grep zh

在这里插入图片描述

我们可以选择 zh_CN.utf8, 可以通过以下方法:

vi /etc/profile

增加配置

export LC\_ALL=zh_CN.utf8
export LANG=zh_CN.utf8


然后保存,执行 source /etc/profile,通过命令 locale 或者 echo $LANG 都可以查看是否生效;

完成上面修改后,我们到界面上测试,发现还是问号;

那么我们再进行第二步排查。

3、检查数据库是否设置了正确的字符编码;

这个有两种方式,第一种看配置文件

vi /etc/my.cnf 

查看 [mysqld]、 [mysql] 下的字符编码:
在这里插入图片描述
在这里插入图片描述

第二种,通过mysql 客户端链接mysql,执行 show variables like ‘%char%’查看:

在这里插入图片描述

从这里可以看出 mysql 保存的编码是对的,但是为了一定确认没问题,我们可以做个小测试,创建一个测试表

CREATE TABLE `test` (
  `test` varchar(200) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

然后插入一条数据检查

insert into test (test) value ('张三');

然后执行查询语句:

select \* from test;

验证后发现也能正常显示中文。

然后我只能怀疑是项目的编码设置的有问题了。

4、项目是否指定了正确的字符编码

于是我修改了 springboot 项目的启动文件,增加一段配置:

-Dfile.encoding=UTF-8

最后:学习总结——MyBtis知识脑图(纯手绘xmind文档)

学完之后,若是想验收效果如何,其实最好的方法就是可自己去总结一下。比如我就会在学习完一个东西之后自己去手绘一份xmind文件的知识梳理大纲脑图,这样也可方便后续的复习,且都是自己的理解,相信随便瞟几眼就能迅速过完整个知识,脑补回来。下方即为我手绘的MyBtis知识脑图,由于是xmind文件,不好上传,所以小编将其以图片形式导出来传在此处,细节方面不是特别清晰。但可给感兴趣的朋友提供完整的MyBtis知识脑图原件(包括上方的面试解析xmind文档)

image

除此之外,前文所提及的Alibaba珍藏版mybatis手写文档以及一本小小的MyBatis源码分析文档——《MyBatis源码分析》等等相关的学习笔记文档,也皆可分享给认可的朋友!

外链图片转存中…(img-kBNcqHdX-1714780450229)]

除此之外,前文所提及的Alibaba珍藏版mybatis手写文档以及一本小小的MyBatis源码分析文档——《MyBatis源码分析》等等相关的学习笔记文档,也皆可分享给认可的朋友!

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

  • 22
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值