解决JPA使用root.fetch时报the owner of the fetched association was not present in the select list 问题

在使用JPA Specification 进行多条件查询时,使用root.fetch("xx")关联查询LAZY的属性时,会报如下错误:

org.hibernate.QueryException: query specified join fetching, but the owner of the fetched association was not present in the select list

 原因是由于查询时候除了执行select xxx from A 之外,还执行了select count(*) from A,而select count是不能调用fetch的,所以我们可以根据查询结果的类型来判断是否进行fetch,如果是long类型,则不执行fetch操作;

解决方法如下:

JpaSpecificationExecutor.findAll(new Specification<T>(){  

   public Predicate toPredicate(Root<TabSgUserPackage> root, CriteriaQuery<> query, CriteriaBuilder builder) {  
        if (!query.getResultType().equals(Long.class)) {
            root.fetch("xxx", JoinType.LEFT);
        }
    }
  
})  

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值