通过mybatis从mysql读取的时间和表中的时间不一致

在SpringBoot项目中使用Mybatis进行数据操作时,发现从数据库读取的datetime与实际表中时间不符。主要通过两个步骤解决:检查并调整MySQL的时区设置,以及在Mybatis映射文件中正确设置jdbcType为TIMESTAMP。

通过mybatis从mysql读取的时间和表中的时间不一致

近日在开发一个SpringBoot项目,利用Mybatis来进行Dao的操作。在页面上展示数据的时候发现,时间和数据库表中存的时间不一致。

经过查询资料,通过两步解决了该问题:

一、修改mysql的时区(保留,不一定需要)

参考:《mybatis查询mysql的datetime类型数据时间差了14小时(时区问题)》

mysql> show variables like '%time_zone%';
+------------------+--------+
| Variable_name    | Value  |
+------------------+--------+
| system_time_zone | CST    |
| time_zone        | SYSTEM |
+------------------+--------+
mysql> set global time_zone= '+8:00';
Query OK, 0 rows affected (0.00 sec)

mysql> set  time_zone= '+8:00';
Query OK, 0 rows affected (0.00 sec)

mysql> flush privileges;
Query OK, 0 rows affected (0.04 sec)

mysql> show variables like '%time_zone%';
+------------------+--------+
| Variable_name    | Value  |
+------------------+--------+
| system_time_zone | CST    |
| time_zone        | +08:00 |
+------------------+--------+
2 rows in set (0.00 sec)

二、修改mybatis中映射的jdbcType

mysql的字段类型为datetime,项目中Bean的字段类型为Instant,映射是jdbcType类型应该为:TIMESTAMP

如:

...
@Result(column = "issue_time", property = "issueTime", jdbcType = JdbcType.TIMESTAMP),
...
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值