微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

在更新 Spring Data Jpa 之后获取更新数据的问题

如何解决在更新 Spring Data Jpa 之后获取更新数据的问题

我正在使用@Modifying 进行更新,更新后我正在使用存储库获取数据。但是获取的数据不是更新后的数据,而是更新完成前的数据。 当我使用其他 GET api 获取相同的数据时,会获取更新的数据,但不仅仅是在以相同的方法更新之后。

我的服务类更新方法

public Response update(Integer value,Long id) {

    repository.updateValue(value,id);
    Response res = repository.findById(id);
    return res;
}

我的 Repository 类更新方法

@Transactional
@Modifying
@Query(value = "update T1 set value = :value where id = :id",nativeQuery = true)
int updateValue(Integer value,Long id);

如前所述,我在“res”中获得了以前的值。 有人可以帮忙解决这个问题吗?

解决方法

在@Modifying 注释中添加 clearAutomatically=true 后,更新工作正常。

@Transactional
@Modifying(clearAutomatically = true)
@Query(value = "update T1 set value = :value where id = :id",nativeQuery = true)
int updateValue(Integer value,Long id);

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。