我正在通过休眠生成一个日期并保存在数据库中,当我得到该值并将其与插入之前的值进行比较.结果不平等!
我创建了如下日期
Date rightNow = Calendar.getInstance().getTime(); Task t1 = new Task("My task",rightNow); taskDao.saveOrUpdate(t1); Task taskR1 = taskDao.get(t1.getIdTask()); assertEquals("They should have to be equal dates",taskR1.getDate(),t1.getDate());
我收到了这个错误
< 2014-04-11 23:13:13.0>不同于< Fri Apr 11 23:13:13 CEST 2014>
java.lang.AssertionError: They should have to be equal dates expected:<2014-04-11 23:13:13.0> but was:<Fri Apr 11 23:13:13 CEST 2014>
与问题相关的额外信息
课程任务
@Entity @Table(name = "t_task") public class Task { @Id @GeneratedValue(strategy = GenerationType.AUTO) @Column(name = "idTask") private long idTask; ... @Column(name = "date") private Date date; ...
MysqL表t_task
CREATE TABLE IF NOT EXISTS `mytask`.`t_task` ( `idTask` INT(11) UNSIGNED NOT NULL AUTO_INCREMENT,`date` DATETIME NOT NULL ...
我在Task中创建了一个新的hashCode()和equals()函数,只有日期字段,所以它是不同的.
@Override public int hashCode() { final int prime = 31; int result = 1; result = prime * result + ((date == null) ? 0 : date.hashCode()); return result; } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (!(obj instanceof Task)) return false; Task other = (Task) obj; if (date == null) { if (other.date != null) return false; } else if (!date.equals(other.date)) return false; return true; }
任何的想法?
解决方法
这是由java.sql.Timestamp混乱设计引起的完全混乱,并且由Hibernate返回此类的实例.实际上,您将java.util.Date实例存储到您的实体中. Hibernate将其转换为java.sql.Timestamp以将其插入数据库中.但是当它从数据库中读取数据时,它不会将时间戳转换回java.util.Date.这很好,因为Timestamp扩展了Date.
但是时间戳永远不应该延长日期.实际上,Date精确到毫秒,而Timestamp精确到纳秒.为了能够比较两个Timestamp的纳秒部分,Timestamp会覆盖equals()方法,但会通过这样做来打破它的一般契约.最终结果是,您可以将date.equals(timestamp)设置为true,但timestamp.equals(date)为false.
我的建议:永远不要将Date实例与equals()进行比较.请改用compareto().
原文地址:https://www.jb51.cc/java/124832.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。