【问题标题】:Javers showing difference while comparing java.sql.Timestamp with java.util.Date fields even if there is no changes made to the date fieldsJavers 在比较 java.sql.Timestamp 和 java.util.Date 字段时显示差异,即使日期字段没有更改
【发布时间】:2019-06-07 15:44:01
【问题描述】:

我正在尝试使用 Javers 比较两个 VO,但是由于 java.sql.Timestampjava.util.Date 字段比较显示检测到更改但实际上并没有对字段进行任何更改,我遇到了一些困难!

下面是我的场景:

@Entity
class A {
  @Id private long id;
  private SortedSet<B> objB;

  public SortedSet<B> getObjB() {
    return objB;
  }

  public void setObjB(SortedSet<B> objB) {
    this.objB = objB;
  }
}

@Entity
class B implements comparable<B> {
  @Id private long id;
  private java.util.Date startDate;
  private java.util.Date endDate;

  public Date getStartDate() {
    return startDate;
  }

  public void setStartDate(Date startDate) {
    this.startDate = startDate;
  }


  public Date getEndDate() {
    return endDate;
  }

  public void setEndDate(Date endDate) {
    this.endDate = endDate;
  }

  equals(...) {
    ...
  }
  hashCode(...) {
    ...
  }
}

class JaversDateCompareDemo {
  public static void main(String[] args) {
    B b1= new B();
    b1.setStartDate(new java.sql.Timestamp(1559822652957));
    b1.setEndDate(new java.sql.Timestamp(1559822652957));

    SortedSet<B> s1 = new TreeSet();
    s1.add(b1);

    B b2 = new B();
    b2.setStartDate(1559822652957);
    b2.setEndDate(1559822652957);

    SortedSet<B> s2 = new TreeSet();
    s2.add(b2);

    A a1 = new A();
    a.setObjB(s1);

    A a2 = new A();
    a.setObjB(s2);

    Javers javers = JaversBuilder.javers().withListCompareAlgorithm(lca).build();
    Diff diff = javers.compare(a1, a2);
    System.out.println(diff.prettyPrint());
  }
}

输出:

Diff:
* changes on A/xxx :
  - 'objB/xxx.endDate' value changed from '2019-06-06 12:04:12.976' to 'Thu Jun 06 12:04:12 GMT 2019'
  - 'objB/xxx.startDate' value changed from '2019-06-06 12:04:12.976' to 'Thu Jun 06 12:04:12 GMT 2019'

我的代码库实际上非常大,我们希望有一个标准的方法来比较和维护更改的审计日志,问题是,目前我正在手动解析从 java.sql.Timestampjava.util.Date 的日期字段。它已定义(非常忙碌)。

所以

  1. 我想知道是否有更好的方法来避免这种变化。
  2. Javers 是否提供比较不同类型的 2 个日期的功能(如上所述)。
  3. 如果 Javers 目前没有此类功能可用,是否可以将此功能添加到其中。我认为这在这种情况下会非常有帮助。

谢谢。

【问题讨论】:

    标签: java javers


    【解决方案1】:

    JaVers 使用equals() 比较Values,看起来java.sql.Timestamp 不等于java.util.Date,即使它们具有相同的值。

          given:
          Timestamp t = new Timestamp(1559822652957)
          Date d = new Date(1559822652957)
    
          when:
            println d
            println t
    
          println ('d.equals(t) ' + d.equals(t))
          println ('t.equals(d) ' + t.equals(d))
    
          then:
          t.time == d.time
    

    输出

    Thu Jun 06 14:04:12 CEST 2019
    2019-06-06 14:04:12.957
    d.equals(t) true
    t.equals(d) false
    

    【讨论】:

    • 感谢@Bartek 的及时回复。
    • 我现在看到 Timestamp 和 Date equals() 的工作方式与 javadoc 完全不同。这正是我的场景(t.equals(d))。您对在这种情况下可以做什么有任何建议,否则将不得不将每个时间戳值转换为日期。谢谢。
    • 尝试写一个CustomComparator 并为这两种类型注册。
    猜你喜欢
    • 1970-01-01
    • 2017-10-08
    • 2015-12-01
    • 2020-12-16
    • 2019-02-18
    • 2020-01-26
    • 1970-01-01
    • 2018-05-15
    • 2010-10-24
    相关资源
    最近更新 更多