- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我对以毫秒为单位的日期管理有疑问。我理解需要使用 TIMESTAMP 来存储毫秒数:
@Temporal(TIMESTAMP)
@Column(name="DATE_COLUMN", nullable = false)
@Override public java.util.Date getDate() { return this.date; }
但是如果我无法将这个日期与另一个 java.util.Date 实例进行比较,除非我注意 equals() 调用的顺序,因为 this.date
实例是一个 java .sql.时间戳。如何从 JPA 获取 java.util.Date?因为来自JPA的日期,即使方法签名是一个java.util.Date,实际上也是一个java.sql.Timestamp的实例。
java.util.Date newDate = new Date(this.date.getTime());
this.date.equals(newDate) == false
newDate.equals(this.date) == true
我尝试在持久性类中修改我的方法:
@Override
public Date getDate() {
return this.date == null ? null : new Date(this.date.getTime());
}
它可以工作,但是对于大量数据来说效率不高。
还有其他选择:
我可以修改我的持久性类的设计,使用 @PostLoad
以便在我检索它之后从持久化的日期创建一个 java.util.Date。
我想知道我是否无法使用 ClassTransformer
获得结果?
你遇到过这样的问题吗?我有什么不正确的吗?处理此问题的最佳方法是什么?
最佳答案
TBH,我不确定它的确切状态,但 Hibernate(这是您的 JPA 提供程序,对吗?)处理 TIMESTAMP
列的方式确实可能存在问题。
为了将 SQL TIMESTAMP
映射到 java.util.Date
,Hibernate 使用 TimestampType
,它实际上会分配一个 java.sql.Timestamp
。到您的 java.util.Date
属性。虽然这是“合法的”,但问题是 Timestamp.equals(Object)
是不对称的(到底为什么?!),这打破了 的语义>Date.equals(Object)
.
因此,如果 myDate
映射到 SQL TIMESTAMP
,则您不能“盲目地”使用 myDate.equals(someRealJavaUtilDate)
,这当然不是真正可以接受的。
但是尽管这已经在 Hibernate 论坛上进行了广泛的讨论,例如在 this thread和 this one (阅读所有页面),似乎 Hibernate 用户和开发人员从未就此问题达成一致(参见 HB-681 等问题),我只是不明白为什么。
也许这只是我,也许我只是错过了一些对其他人来说很简单的东西,但这个问题对我来说很明显,虽然我认为这是愚蠢的 java.sql.Timestamp
作为罪魁祸首,我仍然认为 Hibernate 应该保护用户免受这个问题的影响。我不明白为什么加文不同意这一点。
我的建议是创建一个演示该问题的测试用例(应该非常简单)并(再次)报告该问题以查看您是否从当前团队获得更多积极反馈。
与此同时,您可以使用自定义类型自己“修复”问题,方法如下(取自论坛并按原样粘贴):
public class TimeMillisType extends org.hibernate.type.TimestampType {
public Date get(ResultSet rs, String name) throws SQLException {
Timestamp timestamp = rs.getTimestamp(name);
if (timestamp == null) return null;
return
new Date(timestamp.getTime()+timestamp.getNanos()/1000000);
}
}
关于java - 如何使用 java.sql.Timestamp 作为真正的 java.util.Date 与 JPA,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4014303/
我在这个网站上发布的代码有这个问题 https://developers.google.com/drive/quickstart-cs是 Google Drive 快速入门的开发人员站点。我按照网站上
我正在尝试制作一个非常简单的 Kafka Producer,目前正在关注 producer example除了我的制作人没有分区程序类。 将所需文件导出到 jar 后,我将它们传输到我的 Linux
问题 在java中,我有一个“Util项目”,在进行单元测试时使用另一个“Mock项目”。 我的问题是“模拟项目”也使用“Util项目”来构建一些模拟对象。 当我使用 Maven 构建项目时,我无法构
据我所知,这些包已经存在很长时间了。但是,我从未见过它们的实际用法。而且这些包似乎不成熟,不再维护。如果是,为什么这些包现在存在? 最佳答案 包裹automata被 scala.xml.dtd 使用,
关闭。这个问题需要debugging details .它目前不接受答案。 想改进这个问题?将问题更新为 on-topic对于堆栈溢出。 1年前关闭。 Improve this question Co
在java.util.Collections中,有一个方法: public static void fill(List list, T obj) 用第二个参数指定的对象填充第一个参数指定的List。
我不明白它要我做什么。分配给 sentence正在工作: val sentences : java.util.List[CoreMap] = document.get(classOf[Sentence
在我的 React 应用程序中,我想使用一些实用程序。我见过两种不同的方法。第一个是,只是创建函数并将其导出。第二个是,创建一个 Util 类并导出一个对象,这样它就不能被实例化(静态类)。 clas
我有一个 util 类,它接受 String jwtToken 和 Key key 并使用 io.jsonwebtoken.jwts 解码 jwt。 但是,我无法对此进行测试。原因是,我无法模拟公钥并
我有使用目标命名空间的专有架构 xmlns:ax216="http://util.java/xsd" 这给我带来了从 java (java.util.xsd) 开始生成禁止的(由 Java 安全管理器
我正在阅读集合以查看 Javadocs 中的实现层次结构。 Collections声明为public class Collections extendds Object Collection声明为pu
我正在使用 Spring-boot 应用程序,我可以在其中连接 Azure 应用程序配置。但是当我尝试使用内容类型应用程序/JSON 读取值时出现错误。 我的Java类 @ConfigurationP
我正在使用 Spring-boot 应用程序,我可以在其中连接 Azure 应用程序配置。但是当我尝试使用内容类型应用程序/JSON 读取值时出现错误。 我的Java类 @ConfigurationP
我在使用格式说明符时遇到问题。这是否意味着我正在使用 %d? public static void main(String[] args) { double y, x; for (x =
鉴于此代码 import java.util.Iterator; private static List someList = new ArrayList(); public static void
我正在 HackerEarth 解决问题,我无法弄清楚为什么我的程序在命令行上正确运行并给出正确的结果,但在代码编辑器上运行时却给出 java.util.NoSuchElementException
我正在尝试使用以下代码使用对象列表列表中的数据填充tableModel readExcel.readSheet(0): TableModel tableModel = new DefaultTabl
java.util.Set 、 java.util.List 和其他 Collection 接口(interface)不可序列化。需要一个简单、直接的解决方案来在可序列化的 POJO 中使用它。 pu
我试图从 servlet 返回数据库搜索结果的 ArrayList 以显示在 jsp 页面上。 在servlet中设置arraylist作为请求的属性,并将请求转发到jsp页面。当我尝试在 jsp 页
我是android新手,最近我试图从firebase中提取数据到recyclerview/cardview中以垂直布局显示数据,它显示将Hashmap转换为Arraylist的错误,其中代码是:
我是一名优秀的程序员,十分优秀!