Java - 使用DBUtils BeanListHandler将查询中的所有日期转换为JodaTime的DateTime

时间:2017-12-20 11:59:44

标签: java datetime timestamp jodatime apache-commons-dbutils

我正在使用BeanListHandler将数据库中的行转换为POJO。它一直很好,但现在我需要做一些日期比较。为此,我决定使用JodaTime。

我希望查询结果集中的所有时间戳/日期类型行都转换为JodaTime的DateTime类而不是默认的Timestamp。我尝试使用setter来执行此操作,但BeanListHandler似乎没有调用setter来设置值(它是否使用反射?)。

我应该怎么做呢?

1 个答案:

答案 0 :(得分:0)

我认为没有直接的解决方案。一种解决方法是在POJO中同时包含TimestampDateTime字段,并在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;
    }



}