加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

如何获取spring数据jpa中更新记录的数量?

发布时间:2020-12-15 01:27:10 所属栏目:大数据 来源:网络整理
导读:我使用spring数据jpa和hibernate作为jpa持久性提供程序. 我在我的应用程序中使用本机查询.有一些更新查询,我想获得更新查询执行时更新的实际记录数.在spring数据jpa中有没有办法做到这一点? 我目前正在遵循以下方法; @Modifying@Query(value="update table

我使用spring数据jpa和hibernate作为jpa持久性提供程序.

我在我的应用程序中使用本机查询.有一些更新查询,我想获得更新查询执行时更新的实际记录数.在spring数据jpa中有没有办法做到这一点?

我目前正在遵循以下方法;

@Modifying
@Query(value="update table x set x_provision = ?1 where x_id = ?2",nativeQuery=true)
int updateProvision(Integer provision,Integer id);

@Transactional添加在服务层上.

这里的问题是,当表更新时,我将计数为1.但是在某些情况下没有更新行.在这种情况下,我也将计数作为1.但我希望收到更新的实际记录数,有时为0.

如果我在这里做错了,有人可以告诉我吗?

最佳答案
如果您看一下用于执行此查询的ModifyingExecutor

@Override
protected Object doExecute(AbstractJpaQuery query,Object[] values) {
    int result = query.createQuery(values).executeUpdate();
    if (em != null) {
        em.clear();
    }
    return result;
}

然后你看,它只委托给原生JPA基础设施,以返回更新元素的数量.

因此,这可能与使用过的数据库或ORM框架配置有关,除此之外,您编写的查询应该返回正确的结果.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读