sql new vo对象 时间的处理

通常我们喜欢将hql查询结果封装到POJO对象
 syntax:
 select new POJO(id,name) from POJO ;


 这种封装需要POJO类提供对应构造器,POJO(id,name)构造方法。

 

 但使用中经常会抛这样的异常:Unable to locate appropriate constructor on class。

出现这个异常需要检查以下几种情况:
1)参数构造器的参数类型是否正确
2)参数构造器的顺序和hql中的顺序是否一致
3)参数构造器的参数个数是否和hql中的个数一致
4)参数构造器的参数类型是否TimeStamp

其中第4种情况较为复杂

这里提供参数构造器的参数类型是TimeStamp的解决方法:
super.getHibernateTemplate().find("select new Student(id,name,date) from Student");

实体类:
public class Student {
private Long id;
private String name;
private String address;
private Timestamp date;
public Long getId() {
   return id;
}
public void setId(Long id) {
   this.id = id;
}
public String getName() {
   return name;
}
public void setName(String name) {
   this.name = name;
}
public String getAddress() {
   return address;
}
public void setAddress(String address) {
   this.address = address;
}
public Timestamp getDate() {
   return date;
}
public void setDate(Timestamp date) {
   this.date = date;
}
public Student() {
   super();
}

//注意些处的构造方法
public Student(Long id, String name, Object date) {
this.id=id;
   this.name = name;
   this.date = stringToTimestamp(date.toString());
}


public static Timestamp stringToTimestamp(String dateStr){
 
   SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
   Calendar cal = Calendar.getInstance();
   try {
    Date date = sdf.parse(dateStr);
    date.getTime();
    cal.setTime(date);
    return new Timestamp(cal.getTimeInMillis());
   } catch (ParseException e) {
    e.printStackTrace();
   }
 
   cal.setTime(new Date());
   return new Timestamp(cal.getTimeInMillis());
}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值