hibernate实体类构造方法内含有Timestamp类型变量时"Unable to locate approprite constructor"错误解决方法

11 篇文章 0 订阅
3 篇文章 0 订阅

在使用hibernate时,有时想获取部分字段的结果集,可以用如下方法:

可以在hql中使用select new 包名.类名(属性1,属性2,....)  from 实体类,同时要在实体类中添加带参的构造方法,参数的个数和顺序与(属性1,属性2,....)要保持一致,如此我们得到的List中存放的依然是实体类的对象。

例:

select new User(u.name,u.createTime) from User u order by u.createTime;

public User(String name,Timestamp createTime){
this.name = name;
this.createTime = createTime;
}

然后便遇到了如下错误:


解决方法:(2种)

public User(String name,Date createTime){
this.name = name;
this.createTime = Timestamp.valueOf(DateFormat.dateToNor(createTime))
}

or

public User(String name,Object createTime){
this.name = name;
this.createTime = Timestamp.valueOf(createTime.toString());
}


其中DateFormat是我自定义的工具类,其内的dateToNor()方法如下:

public static String dateToNor(Date dates){
		String time= date.format(dates);
		return time;
	}

public static SimpleDateFormat date = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");

如此包含部分参数的构造函数便可匹配了。

参考博文:hibernate hql查询指定字段并获得结果集  hibernate中实体类构造方法中含有Timestamp 类型变量的"no appropriate constructor.." 错误提示的解决办法

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值