SpringBoot中集成Mybatis配置数据库连接的若干问题

今天在学习Mybatis的时候,在创建SpringBoot项目并引入Mybatis依赖时遇到了几个问题

1. mybatis-spring-boot-starter的版本问题

mybatis-spring-boot-starter版本对MyBatis-Spring、SpringBoot、JDK版本的适配要求可以参考此网址:mybatis-spring-boot-autoconfigure – Introductionicon-default.png?t=N7T8http://mybatis.org/spring-boot-starter/mybatis-spring-boot-autoconfigure/

省流来说就是下图

即3.0版本只支持SpringBoot3及JDK17,所以最开始创建SpringBoot工程不小心创建成了SpringBoot3版本的,在依赖选择时选择了Mybatis Framework,自动引入的是3.0.2版本的mybatis-spring-boot-starter,后续手动修改了SpringBoot版本为2.7.16,但是没有修改mybatis-spring-boot-starter的版本为2.3之前,因此运行测试就报了错

 2. mysql-connector-java的版本问题

引入数据库连接有两种写法:

1)使用mysql-connector-j引入最新版本的驱动包

1)使用mysql-connector-java引入旧版本的驱动包

因为自己电脑上装的是5.7版本的MySQL,今天以为8.0版本的连接驱动包没办法连接5.7版本的MySQL,要使用5.1版本的连接驱动才行,搞了半天,来回切换连接驱动的版本。其实8.0版本的连接驱动是可以向下兼容5.7版本的MySQL的,但是在配置数据库的连接信息上有一些不同

5.1版本的mysql-connector中的驱动类Driver位置为 com.mysql.jdbc.Driver,8.0版本的mysql-connector中的驱动类Driver位置为 com.mysql.jc.jdbc.Driver,如图:

 

2. 配置数据库连接信息的URL问题

今天使用5.1版本的数据库连接的时候,URL直接输入 jdbc:mysql://localhost:6050/mybatis即可,后边不用修改属性,但是在使用8.0版本的数据库连接的时候,先是报了一个警告:

Wed Oct 18 19:38:41 CST 2023 WARN: Establishing SSL connection without server's identity verification is not recommended. According to MySQL 5.5.45+, 5.6.26+ and 5.7.6+ requirements SSL connection must be established by default if explicit option isn't set. For compliance with existing applications not using SSL the verifyServerCertificate property is set to 'false'. You need either to explicitly disable SSL by setting useSSL=false, or set useSSL=true and provide truststore for server certificate verification.

翻译过来就是 不建议在未验证服务器身份的情况下建立 SSL 连接。根据 MySQL 5.5.45+、5.6.26+ 和 5.7.6+ 的要求,如果未设置显式选项,则必须默认建立 SSL 连接。为了与不使用 SSL 的现有应用程序保持一致,verifyServerCertificate 属性被设为 "false"。要么通过设置 useSSL=false 明确禁用 SSL,要么设置 useSSL=true 并提供用于验证服务器证书的信任库。

我没有具体去搞懂上述警告的意思,先放一放。

还报了错:

主要错误描述为

Failed to obtain JDBC Connection; nested exception is java.sql.SQLException: The server time zone value 'Öйú±ê׼ʱ¼ä' is unrecognized or represents more than one time zone. You must configure either the server or JDBC driver (via the serverTimezone configuration property) to use a more specifc time zone value if you want to utilize time zone support.

 

翻译一下为 获取 JDBC 连接失败;嵌套异常是 java.sql.SQLException: 服务器时区值 "Ö¹ú±ê׼ʱ¼ä "未被识别或代表多个时区。如果要使用时区支持,必须配置服务器或 JDBC 驱动程序(通过 serverTimezone 配置属性)以使用更具体的时区值。

查了一下后发现是要设置时区,不然在中国会与默认时区(UTC)产生时差

在URL后加上

?useSSL=false&characterEncoding=utf8&useJDBCCompliantTimezoneShift=true&serverTimezone=Asia/Shanghai

即这样

spring.datasource.url=jdbc:mysql://localhost:6050/mybatis?useSSL=false&characterEncoding=utf8&useJDBCCompliantTimezoneShift=true&serverTimezone=Asia/Shanghai

设置参数的含义参见解决mysql时区问题以及SSL问题_usetimezone-CSDN博客

 

以上就是今天第一次接触SpringBoot+Mybatis遇见的问题,记录一下,牢记这些特性

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值