JPA查询修改数据,但是未保存到数据库,数据库却修改了,因为对查询出的Entity实体对象,修改set了属性。导致事务提交时候修改了数据库的数据

发布时间 2023-10-23 12:58:22作者: sunny123456

JPA查询修改数据,但是未保存到数据库,数据库却修改了,因为对查询出的Entity实体对象,修改set了属性。导致事务提交时候修改了数据库的数据

使用JPA查询数据,对查询出来的结果进行修改,但是不保存数据库,最终数据库却做了同样的修改。

JPA对象的四种状态

瞬时状态:瞬时状态的实体就是一个普通的java对象,一般为新new出来的实体,没有id,没有和数据库建立练习

托管状态:使用jpa查询出来的对象,例如findById查询返回的对象,此时对象已经持久化,有id,并且和数据库建立了联系,此时修改对象的属性值会被同步到数据库中

在这里插入图片描述
在这里插入图片描述

没有进行save操作,但是此时数据库中的值已经发生改变了

游离状态:当事务提交后,处于托管状态的对象就转变为了游离状态。此时该对象仍有id,但是不在持久化中因此任何对于该对象的修改都不会同步到数据库中。

删除状态:当调用jpa中的方法例如delete对实体进行delete后,该实体对象就处于删除状态。其本质也就是一个瞬时状态的对象。

具体的操作可以看我们代码中的业务,如果我们忘记在最后执行.save方法,此时做修改数据库中的数据是会发生改变的(除第一次保存外)

原文链接:https://blog.csdn.net/scdn_wyy/article/details/124453179