SpringBoot整合MyBatis与MySql8.0

一、前言

之前已经有一篇文章讨论过SpringBoot整合MyBatis,因而此篇不在重复累赘,本文主要是最新版的SpringBoot2.0与MyBatis、最新MySQL8.0整合过程中遇到的问题进行总结。同时,SpringBoot整合MyBatis中可以不用之前那篇那样繁琐的配置,可以使用application.properties文件进行整合。

二、application.yml 与 application.properties 加载顺序

SpringBoot优先加载yml文件,也就是先加载yml文件再加载properties文件。两个文件都可以起到同时配置全局的作用。如果在yml文件中配置了端口为80,在properties文件中配置了8080,那么最后端口是8080,因而properties后加载,覆盖了之前已经配置后的80端口。

其实 application.yml 文件会被优先加载,

而如果同时存在 application.properties 文件,并且存在相同的配置,

那么则会用 application.properties 文件中的配置覆盖之前的配置;

也就是说哪个文件被最后加载,哪个才具有最高级别,

因为最后的,会覆盖前面所有的。
--------------------- 
作者:微wx笑 
来源:CSDN 
原文:https://blog.csdn.net/testcs_dn/article/details/79010798 
版权声明:本文为博主原创文章,转载请附上博文链接!

三、application.properties示例

#设置Tomcat端口,默认8080
server.port=8080
#设置项目ContextPath
server.context-path=/
#设置Tomcat编码
server.tomcat.uri-encoding=UTF-8
#设置视图解析器路径
spring.mvc.view.prefix=/WEB-INF/views/
#设置视图解析器后缀
spring.mvc.view.suffix=.jsp
 
#数据库配置
spring.datasource.url=jdbc:mysql://localhost:3306/tuzisong?useUnicode=true&characterEncoding=utf-8&zeroDateTimeBehavior=convertToNull&allowMultiQueries=true
spring.datasource.username=root
spring.datasource.password=F6m3G3j6
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
 
#配置.xml文件路径
mybatis.mapper-locations=classpath:mapper/*.xml
#配置模型路径
mybatis.type-aliases-package=cn.copy.model

MyBatis通过上述两行,便可在Resource的mapper中读取xml文件和对应的实体类,如果数据库使用的MySQL8.0,加载类需要更改,下文有论述。

如果想了解整体的配置,文件目录结构,详细可以参考该示例的原文:[1]

四、使用MySQL8.0

使用MySQL8.0的时候会出现兼容性的问题。

1、数据库连接工具无法连接[2]

mysql8.0默认采用caching_sha2_password的加密方式

第三方客户端基本都不支持这种加密方式,只有自带的命令行支持

所以需要修改加密方式。在MySQL自带的客户端client中输入如下命令:

ALTER USER 'username'@'ip_address' IDENTIFIED WITH mysql_native_password BY 'password';

示例:
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'root';

2、SpringBoot通过jdbc无法连接到MySQL

先更换最新的jar包(当前最新为2018-09-27,8.0.13),在maven中添加如下依赖:

<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>8.0.13</version>
</dependency>

同时,application.xml中配置文件中应该改为:

url: jdbc:mysql://localhost:3306/db_test?characterEncoding=utf8&useSSL=false&serverTimezone=UTC&rewriteBatchedStatements=true
 
driver: com.mysql.cj.jdbc.Driver

详细内容可以参考文章[3]

五、后言

本文需要对SpringBoot与MyBatis有一定的了解,时代在向前,版本在更新,在重新整合的过程中遇到的各种问题,集合各方的观点与解决方案,总结形成此文。

Reference:

[1] 阿豆根, Spring Boot+Mybatis+MySql 完整整合教程, https://blog.csdn.net/qq_33768099/article/details/79787215

[2] https://stackoverflow.com/questions/49194719/authentication-plugin-caching-sha2-password-cannot-be-loaded

[3] Xanthuim, MySQLNonTransientConnectionException: Could not create connection to database server., https://blog.csdn.net/qq_15003505/article/details/80463174

原文地址:https://www.cnblogs.com/ryelqy/p/10104030.html