簡體   English   中英

如何在Play Framework中使用Ebean比較日期?

[英]How to compare dates using Ebean in Play Framework?

Scenario.java

package models;

import java.util.*;

import javax.persistence.*;

import play.db.ebean.*;

@Entity
public class Scenario extends Model {

    @Id
    public Long id;
    public String name;
    public boolean isPublic;
    public boolean isAccepted;
    public Date expirationDate;
    @ManyToOne
    public User owner;
    @ManyToMany
    public List<User> members = new ArrayList<User>(); 
    @OneToMany(cascade = CascadeType.ALL)
    public List<Checkpoint> checkpoints = new ArrayList<Checkpoint>();

    public static Model.Finder<Long, Scenario> find =
            new Finder<Long, Scenario>(Long.class, Scenario.class);

    public Scenario(String name, boolean isPublic, Date expirationDate, User owner) {
        this.name = name;
        this.isPublic = isPublic;
        this.expirationDate = expirationDate;
        this.owner = owner;
        this.isAccepted = false;
        this.members.add(owner);
    }

    public static Scenario create(String name, boolean isPublic, Date expirationDate,
            String owner) {
        Scenario scenario = new Scenario(name, isPublic, expirationDate, User.find.ref(owner));
        scenario.save();
        scenario.saveManyToManyAssociations("members");
        return scenario;
    }

    public static List<Scenario> findNotExpired(Date date) {
        return find.where().or(
                com.avaje.ebean.Expr.lt("expirationDate", date),
                com.avaje.ebean.Expr.isNull("expirationDate")
                ).findList();
    }
}

考試:

@Test
    public void findScenariosNotExpired() {
        new User("bob@gmail.com", "Bob", "secret").save();
        new User("jane@gmail.com", "Jane", "secret").save();
        SimpleDateFormat dt = new SimpleDateFormat("yyyy-mm-dd hh:mm:ss"); 
        Scenario.create("Scenario 1", false, null, "bob@gmail.com");
        try {
            Scenario.create("Scenario 2", false, dt.parse("2013-12-12 00:00:00"), "jane@gmail.com");
            Scenario.create("Scenario 3", false, dt.parse("2013-10-10 00:00:00"), "jane@gmail.com");
        } catch (ParseException e) {
            System.err.println("Problem with date parsing");
            e.printStackTrace();
        }

        List<Scenario> results = Scenario.findNotExpired(new Date());
        assertEquals(2, results.size());
    }

測試結果如下:

[error] Test models.ModelsTest.findScenariosNotExpired failed: expected:<2> but was:<3>

在測試中我通過了new Date()因為它應包括今天的日期(2013年10月13日)。 這就是為什么我希望大小為2(一個空和一個日期在今天之前)。

我應該改變什么? 我想問題可能出在com.avaje.ebean.Expr.lt("expirationDate", date) - 可以比較這樣的日期嗎?

您需要使用MM而不是mm

運用

SimpleDateFormat dt = new SimpleDateFormat("yyyy-mm-dd hh:mm:ss");

dt.parse("2013-12-12 00:00:00") evaluates to Sat Jan 12 00:00:00 EST 2013

dt.parse("2013-10-10 00:00:00") evaluates to Thu Jan 10 00:00:00 EST 2013

而是使用,

SimpleDateFormat dt = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss"); 

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM