我正在使用BeanListHandler
将数据库中的行转换为POJO。它一直很好,但现在我需要做一些日期比较。为此,我决定使用JodaTime。
我希望查询结果集中的所有时间戳/日期类型行都转换为JodaTime的DateTime
类而不是默认的Timestamp
。我尝试使用setter来执行此操作,但BeanListHandler
似乎没有调用setter来设置值(它是否使用反射?)。
我应该怎么做呢?
答案 0 :(得分:0)
我认为没有直接的解决方案。一种解决方法是在POJO中同时包含Timestamp
和DateTime
字段,并在DateTime
属性的setter方法中设置Timestamp
值,如示例所示下方。
public class Pojo{
private Timestamp timestamp;
private DateTime dateTime;
public Timestamp getTimestamp() {
if (timestamp == null && dateTime != null) {
this.timestamp = new Timestamp(dateTime.getMillis());
}
return timestamp;
}
public void setTimestamp(Timestamp timestamp) {
if (dateTime == null && timestamp != null) {
this.dateTime = new DateTime(timestamp.getTime());
}
this.timestamp = timestamp;
}
public DateTime getDateTime() {
if (dateTime == null && timestamp != null) {
this.dateTime = new DateTime(timestamp.getTime());
}
return dateTime;
}
public void setDateTime(DateTime dateTime) {
if (timestamp == null && dateTime != null) {
this.timestamp = new Timestamp(dateTime.getMillis());
}
this.dateTime = dateTime;
}
}