获取数据库时间相差8小时_JAVA 程序展示时间与数据表保存的时间相差了13个小时...

当JAVA程序展示时间与数据库保存的时间出现差异时,作者通过排查确定问题可能源于时区设置。了解到Java默认将MySQL的CST视为UTC-5,而实际使用的是UTC+8,导致时间相差13小时。解决方案包括修改数据库配置或连接字符串中的时区设置。通过这次经历,作者认识到解决问题的思维方式的重要性。
摘要由CSDN通过智能技术生成

这会在学习算法,微信的声音响起,测试说,有个小问题,讲真的,最怕测试突然想起你。



测试甩了三张截图给我,说你的保存时间不对啊,奇怪了,放假前还好好的,怎么一回来就出问题了。



54853f77a87c946baab61577696564e9.png

swagger展示的数据



bce62fb44750966d2137bde5cb51f20b.png

数据表展示的时间



不知道你们有木有发现不对劲,数据表的时间比 Java 代码展示的时间少了。



分析

我开始分析了,放假前,是没问题的,后面也去改,排除是我代码的问题,我叫来了跟我对接的前端,问他是不是修改了,他说有给我传时间。



我让他修改一下,后面发现问题依旧,于是把前端代码给排除了。



突然有个大胆的猜测,既然不是前后端的问题,是不是大佬们改了什么底层的东西影响到的。



这会旁边的大佬来拿我的零食吃,我顺手逮住他问了个便,他说既然是时间不一致,那可能是时区不一致导致的,他举了个例子,GTM(格林尼治)和UTC(协调世界时)。



巴拉巴拉....大概意思说有这么两种时间协议,估计我的 Java 代码时间协议与数据库协议不一致导致的。



大佬给了我这点提示,我算了一下 Java 代码展示的时间比数据表多了 13 个小时,刚刚好。



为了小心验证我的猜想,我让测试区试一下其他以前的功能,不出所料,其他模块的功能也是时间出问题了。



且前端展示的时间格式是正确的,只是数据表不正确。



好像有眉目了,按着这个关键词去搜索,果然!找到了。



原来 Java 和 Mysql 协商时区时把 Mysql 的 CST 时间以美国中部时间:UTC-5 当做标准。



而我用的是东八区的北京时间 UTC+5,所以我从数据库中读取的 UTC-5 时间到了 Java 程序里就自动转化为 UTC+8 时间,也就比数据库里的时间多了 13 个小时。



解决

网上有这么几种解决方案:

1)修改数据库配置信息(不推荐)

my.cnf(在/etc/my.cnf或者/etc/mysql/my.cnf),然后重启 MySQL 服务器



default-time-zone = '+8:00'



2)修改数据库配置文件,在连接字符串中设置时区(推荐)



spring.datasource.url = jdbc:mysql://127.0.0.1:3306/DataBaseName?useUnicode=true&characterEncoding=utf8&serverTimezone=Asia/Shanghai

或者

spring.datasource.url = jdbc:mysql://127.0.0.1:3306/DataBaseName?useUnicode=true&&characterEncoding=UTF-8&serverTimezone=GMT%2b8



收获

我觉得最大的收受是解决问题的思维得到锻炼,问题是层出不穷的,能用经验解决当然好,就像大脑的缓存一样,高速存取。



可我只是个练习一年都不到的实习生,积累不是很多,若有良好的解决问题思维,便可以不变应万变。



存入数据库时间差8小时的问题通常是由于时区设置不正确导致的。在Java中,使用new Date()获取时间是根据JVM默认的时区来确定的,而JVM默认使用的是0时区的时间,与北京时间相差8小时。当将数据存入数据库时,数据库服务器会将本地时间转换为服务器所对应的时区,即0时区,所以会再次相差8小时。当返回给前端时,如果使用了Spring Boot的@RestController或@Controller+@ResponseBody注解,返回值会被默认的Jackson框架转换为Json格式,而Jackson框架默认的时区是GMT,相对于中国是少了8小时,所以最终返回到前端的结果会相差8小时。解决这个问题的方法有两种: 1. 手动设置JVM时间:将时间改为第8时区的时间,可以使用以下代码进行设置: TimeZone.setDefault(TimeZone.getTimeZone("GMT+8")); 2. 在配置数据库的URL上加上"serverTimezone"参数,确保存数据库时间是正确的。例如: jdbc:mysql://localhost:3306/datasource?serverTimezone=GMT%2B8 同时,还需要确认配置了Jackson的"time-zone"参数,确保给前端返回的时间是正确的。例如: jackson: time-zone: GMT+8 date-format: yyyy-MM-dd HH:mm:ss 需要注意的是,如果只是手动设置JVM时间,而JVM仍然是后台0时区的时间,那么在后台执行逻辑时仍然会出现时间相差8小时的问题。因此,建议使用第一种方法,直接将整个JVM改为北京的8时区。总结起来,这个问题的根本原因是时区设置不正确。\[1\]\[2\]\[3\] #### 引用[.reference_title] - *1* *3* [java获取时间相差8小时的问题及解决方式](https://blog.csdn.net/qq_42031483/article/details/100625564)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [springboot + 数据库时间差8小时](https://blog.csdn.net/gulang00/article/details/130501650)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值