我使用 spring data jpa 和 hibernate 作为 jpa 持久性提供程序。
我在我的应用程序中使用本机查询。有一些更新查询,我想在执行更新查询时获取更新的实际记录数。 spring data 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 框架配置有关,除此之外,您编写的查询应该返回正确的结果。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)