Java 播放 Ebean finder returns 大于查询的错误数据
Java play Ebean finder returns wrong data for greater than query
我有 2 个表,名为 Ride
和 Ride Location
。
Ride.java
@Entity
public class Ride extends Model {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private Long rideId;
@JsonFormat(shape = JsonFormat.Shape.STRING, pattern = "yyyy-MM-dd HH:mm:ss z")
private Date rideDate;
@OneToMany(mappedBy = "ride", cascade = CascadeType.ALL)
private List<RideLocation> rideLocations;
}
RideLocation.java
@Entity
public class RideLocation extends Model {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private Long rideLocationId;
private String locationName;
private float lat;
private float lon;
@JsonBackReference
@ManyToOne(fetch = FetchType.LAZY, cascade = CascadeType.ALL)
private Ride ride;
}
我正在尝试获取 rideDate
大于或等于给定日期且 'locationName' 等于给定位置的所有游乐设施。
List<RideLocation> list = Ebean.find(RideLocation.class).where().ge("ride.rideDate", "2017-09-13").and().like("locationName", "San Jose").findList();
此 returns 数据等于“locationName”。 即使是小于给定日期的日期,此returns数据。我该如何解决这个问题?
您只是试图将日期作为字符串处理,不会给您想要的结果。尝试将字符串转换为日期,或者您也可以比较时间戳(取决于您将其存储在数据库中的方式)。
我有 2 个表,名为 Ride
和 Ride Location
。
Ride.java
@Entity
public class Ride extends Model {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private Long rideId;
@JsonFormat(shape = JsonFormat.Shape.STRING, pattern = "yyyy-MM-dd HH:mm:ss z")
private Date rideDate;
@OneToMany(mappedBy = "ride", cascade = CascadeType.ALL)
private List<RideLocation> rideLocations;
}
RideLocation.java
@Entity
public class RideLocation extends Model {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private Long rideLocationId;
private String locationName;
private float lat;
private float lon;
@JsonBackReference
@ManyToOne(fetch = FetchType.LAZY, cascade = CascadeType.ALL)
private Ride ride;
}
我正在尝试获取 rideDate
大于或等于给定日期且 'locationName' 等于给定位置的所有游乐设施。
List<RideLocation> list = Ebean.find(RideLocation.class).where().ge("ride.rideDate", "2017-09-13").and().like("locationName", "San Jose").findList();
此 returns 数据等于“locationName”。 即使是小于给定日期的日期,此returns数据。我该如何解决这个问题?
您只是试图将日期作为字符串处理,不会给您想要的结果。尝试将字符串转换为日期,或者您也可以比较时间戳(取决于您将其存储在数据库中的方式)。