加入收藏 | 设为首页 | 会员中心 | 我要投稿 晋中站长网 (https://www.0354zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

Jpa使用Update方法进行更新操作,但却没有同步到数据库的原因及解决办法

发布时间:2022-12-08 14:03:40 所属栏目:MySql教程 来源:互联网
导读: Jpa使用Update方法进行更新操作,但却没有同步到数据库的原因及解决办法关于JPA的Update操作解释
JPA的Update操作相当于saveOrUpdate,保存调用的是persist,更新则是merge。该方法会判断要

Jpa使用Update方法进行更新操作,但却没有同步到数据库的原因及解决办法关于JPA的Update操作解释

JPA的Update操作相当于saveOrUpdate,保存调用的是persist,更新则是merge。该方法会判断要操作实体的状态,其实主要是通过当前的实体中是否包含主键,如果含有主键则会进行merge操作,否则就是进行persist操作。

但在使用过程中会出现一种情况,当我们将一个实体从后端查询至前台页面展示,更改数据后,想到后端进行保存,却发现该实体无法保存。其实不能保存是正常的,这首先要从struts2说起了。

当我们在页面点击修改后,我们的参数是通过struts2进行封装成一个实体类的,该实体并没有jpa的entityManager 中托管,是一个游离态的实体,游离态的实体是不能保存到数据库的。

解决方法有如下几种方案:

1.先从数据查询到该实体,在将数据设置到从数据库查询的实体中,然后再保存,这是比较笨的方法。2.通过使用entityManager 中flush方法将已经使用merger方法进行托管的实体数据库更新操作,更新到数据库。

这里稍微解释下eneityManager。

entityManager 有 merge/refresh/flush 方法。

理解eneityManager的这三个方法的作用和区别,首先需要分清楚PersistenceContext 和 EntityManager.

PersistenceContext:是entity的一个实例。

EntityManager:是和PersistenceContext联系在一起的,被用来创建、删除或者查找一个持久化Entity实例。

换句话来说PersistenceContext可以说成是数据库的缓存。

1.merge

通过entityManager将一个存在的实体“同步到”persistenceContext中。

实体的状态将从其单独的状态转换为受persistenceContext管理的状态。

如果Entity是新创建的,则这个方法类似于persist()这个方法。

如果Entity已经存在的,则只作为更新操作。

2.Flush

将PersistenceContext的信息同步到数据库中。

当触发Flush这个动作的时候,所有的实体都将会被insert/update/remove到数据库中。

数据库不会触发Commit的操作。

3.Refresh

Refresh的作用是从数据库中将Entity的状态进行更新操作。如果Entity和数据库中的数据不一致,将更新数据库中的数据到Entity中。

3.通过使用entityManager获得EntityManagerFactory重新创建一个新的entityManager,手动使用事物处理进行更新到数据库 。

EntityManager em = this.getEntityManager().getEntityManagerFactory().createEntityManager();
em.getTransaction().begin();
DpcTypeTimeSet dts = this.update(T);
//this.merge(T);
//this.getEntityManager().flush();//此处注释掉事物处理代码可用,即第二种方法
em.getTransaction().commit();

4.在书写Action类时实现ModelDriven接口。

(编辑:晋中站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!