Hibernate只取出需要用到的字段

今天碰见一个难题,Hibernate中使用hql查询,如果有懒加载,那么在使用springMVC当中会出现转换json的错误,即懒加载导致对象json化失败。

懒加载obj的时候,此时obj是具有一个代理对象的,所以json转化的时候函数认为这个对象是存在的,所以依然去执行get方法进行

转化。但实际上是,加入此时obj实际上为空,也就是代理对象返回的实际对象是空,那么就会报上面所说的nullException了

为了解决这个问题查了很多资料,最后觉得如果是obj的懒加载问题,那么在使用hql查询的时候不查出这个懒加载对象不就行了吗?

照着这个方向,研究了下Hibernate只取出需要用到的字段

 首先Hibernate是支持这样查询的,查询语句如下

String hql = "select new Product(p.id, p.name, p.image) from Product p where p.valid=:valid order by p.id"; 


但是使用这个语句会出现错误:

org.hibernate.hql.ast.QuerySyntaxException: Unable to locate appropriate constructor on class.....  


这个说明没有使用对应的构造函数。

注意了同学们:上面的hql语句中有new Product(p.id, p.name, p.image) 这端代码,这端代码其实是创建一个新的Product对象,那么就需要与此相同的一个构造函数,上面的错误就是告诉你,hibernate没有找到对应的构造函数

好了问题找到了,咱们添加构造函数吧,记住这个构造函数的参数一定要与你hql中想取得的参数一模一样

如下:

//要与hql中的代码高度一致
public Product(Long id, String name, String image){
    this.id = id;
    this.name = name;
    this.image = image;
}


再次运行,就OK了

 

这个事情告诉咱们,要换位思考哦~

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值