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接口。 (编辑:晋中站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |