gpt4 book ai didi

java - 尝试保留已使用毫秒参数初始化的日期时出现 MysqlDataTruncation 异常

转载 作者:行者123 更新时间:2023-11-29 16:16:54 25 4
gpt4 key购买 nike

我正在尝试创建一个距离当前时间几年的日期。我这样做是这样的:

new Date(Math.abs(System.currentTimeMillis() - 94670778000L));

但是由于某种原因,日期的年份部分变成了一些随机的未知数字,导致 jvm 抛出 MysqlDataTruncation 异常。这是完整的消息:

com.mysql.jdbc.MysqlDataTruncation: Data truncation: Incorrect datetime value: '55106056-02-25 05:40:34.461' for column 'lastSeenOnline' at row 1

根据 serhii 的帖子:Data truncation: Incorrect datetime value: ''我应该将 @Temporal 注释从 TemporalType.TIMESTAMP 更改为 TemporalType.TIME 。这确实有帮助,但只是因为日期部分被省略,所以这不是我正在寻找的解决方案。

谁能告诉我我做错了什么?我只是通过毫秒构造函数初始化一个新日期,它应该可以工作,但由于某种原因却不能。

最佳答案

仍然不确定是什么原因导致的,但是从可嵌入类中删除导致问题的字段并将其放置在使用可嵌入类的类中解决了问题。因此,对于面临同样问题的任何人,不要在可嵌入类中使用 @Temporal。

关于java - 尝试保留已使用毫秒参数初始化的日期时出现 MysqlDataTruncation 异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54711622/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com