JPA查询数据并操作数据未保存到数据库,但是数据库中已经修改

jpa中的对象有四种状态:

瞬时状态:瞬时状态的实体就是一个普通的java对象,和持久化上下文无关联,数据库中也没有数据与之对应。

托管状态:使用EntityManager进行find或者persist操作返回的对象即处于托管状态,此时该对象已经处于持久化上下文中,因此任何对于该实体的更新都会同步到数据库中。

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

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

-----------------------------------------------

出现数据库的数据改变的情况就说明你的实体对象处于托管状态,将托管状态变成游离状态即可!

如何实现?

方案一:

@PersistenceContext

private EntityManager entityManager;

//查询数据库的方法

entityManager.clear();


设置游离状态

方案二:

新建一个DTO,DTO中的内容和实体类中的保持一致,将实体类中的内容赋值给DTO即可,操作DTO,数据库查询用实体类,数据操作用DTO!

个人比较推荐第一种,毕竟简单粗暴!

感觉还是mybatis plus好用!

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。