我使用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框架配置有关,除此之外,您编写的查询应该返回正确的结果.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。