javax.persistence.NoResultException: No entity found for query

       当使用查询语句查询实体时,用到getSingleResult()方法,如果无该实体,则会报错  “ No entity found for query ”。getSingleResult()方法本身如此,除非在不确保是否存在该实体的时候不调用该方法。

     解决办法:

           先调用getResultList()方法,判断返回列表是否为空,若为空,则实体不存在,返回null;若不为空,可调用getSingleResult()方法获取实体,或者直接
                     getResultList()。get(0);



  如:

           if(query.getSingleResult()!=null){
                //返回类型为List时不用强转,为什么????
                fq=(FavoriteQuestion) query.getSingleResult();
                return fq.getId();
            }

  改为:

    
            if(query.getResultList().size()!=0){
                fq=(FavoriteQuestion) query.getSingleResult();
                return fq.getId();
            }


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值