四个步骤逐步排查:
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文档)
除此之外,前文所提及的Alibaba珍藏版mybatis手写文档以及一本小小的MyBatis源码分析文档——《MyBatis源码分析》等等相关的学习笔记文档,也皆可分享给认可的朋友!
外链图片转存中…(img-kBNcqHdX-1714780450229)]
除此之外,前文所提及的Alibaba珍藏版mybatis手写文档以及一本小小的MyBatis源码分析文档——《MyBatis源码分析》等等相关的学习笔记文档,也皆可分享给认可的朋友!