###第二次更新,Time:2022/4/20
数据库的时区问题,真的是很让人无语的问题,总是忘了写全,在这里干脆直接把最终版放上,这样写没有问题!(我这里用的是yml)
#数据库配置
datasource:
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://127.0.0.1:3306/xdclass_redis?useUnicode=true&characterEncoding=utf-8&useSSL=false&serverTimezone=Asia/Shanghai
username: root
password: 123456
###################################
今天写mybatis项目时,突然发现连接不了数据库了,提示我时区问题
特别记录一下;
我常写的建立连接的代码是这样的
spring.datasource.url=jdbc:mysql://127.0.0.1:3306/online_xdclass?useUnicode=true&characterEncoding=utf-8
其实这样还不够标准,在一些系统,比如mysql8.0以上或者因为某些位置问题都会导致时区问题,这时你应该在后面加一块代码,如下
spring.datasource.url=jdbc:mysql://127.0.0.1:3306/online_xdclass?useUnicode=true&characterEncoding=utf-8&useSSL=false
其实到这里就基本解决绝大部分问题,但是,还有一小部分同学会碰到更神奇的问题,那就是连接时间(没错,我都遇到了)
在后面加这一块就行&autoReconnect=true
到这基本就是没有问题了,如果还有,请留言告诉我。
最后附上application.properties的代码模板
server.port=8087
spring.datasource.driver-class-name =com.mysql.cj.jdbc.Driver
spring.datasource.url=jdbc:mysql://127.0.0.1:3306/online_xdclass?useUnicode=true&characterEncoding=utf-8&useSSL=false
spring.datasource.username=root
spring.datasource.password=123456
#使用阿里巴巴druid数据源,默认使用自带的
#spring.datasource.type =com.alibaba.druid.pool.DruidDataSource
#开启控制台打印sql
mybatis.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl