SpringBoot 查询根据时间数据-数据库时区错误

本文介绍了一种在使用MyBatis框架时遇到的时区转换错误问题及解决方案。详细阐述了前端传给后端的时间数据在SQL查询中出现8小时偏差的原因,并提供了两种修正方法:一是调整数据库连接时区设置;二是将查询时间映射实体改为字符串格式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近在做一个根据时间段查询数据的表格,发现前端传的时间到打印出sql的查询时间相差8个小时。经过断点调试,发现是mybatis时区转换错误。

前端传到后端的数据是对的,sql打印的时间是错的。 

两种办法:

1.修改连接数据库时区

application.yml 或者application.properties 文件中数据库连接方式追加时区设置serverTimezone=GMT+8,这里转换+号为 %2b 后使用

spring:
    datasource:
        # 主数据源
        datasource:
            driverClassName: com.mysql.jdbc.Driver
            jdbc-url: jdbc:mysql://localhost:3306/testData?useUnicode=true&characterEncoding=utf-8&serverTimezone=GMT%2b8&useSSL=false
            username: root
            password: root

2.查询时映射实体改成string,格式为 "yyyy-MM-dd HH:mm:ss"

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值