关于Jpa使用Update方法进行更新操作,却没有同步到数据库的原因
2017-10-28 23:18
1651 查看
关于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接口。
相关文章推荐
- 关于SubSonic3.0插件使用实体进行更新操作时(执行T.Update()或T.Save()),某些列无法进行修改操作的问题处理
- 关于asp.net网站发布后,使用登录控件和注册控件时出现“数据库只读,无法进行数据更新”的解决方法
- 关于使用dataAdapter.acceptChanges( )方法更新dataSet和数据库的问题
- sql server 还原数据库时提示数据库正在使用,无法进行操作的解决方法
- 网站后台登录aspcms 提示错误号:-2147467259,错误描述:操作必须使用一个可更新的查询。sql=update AspCms_Content set TimeStatus=0 where TimeStatus=1 and Timeing <= 解决方法。
- 关于AcceptChange方法和Update更新数据库问题
- sql server 还原数据库时提示数据库正在使用,无法进行操作的解决方法
- 使用Java对数据库进行基本的查询和更新操作
- 关于在子线程中在run方法执行完之后通知主线程进行操作的方法。(Toast在子线程中无法使用)
- 关于java基础--连接池与通用的操作数据库更新方法
- SpringBoot中连接MYSQL数据库,并使用JPA进行数据库的相关操作
- ADO.NET中使用getchanges方法提速(更新回数据库操作)
- 关于ASP.NET“操作必须使用一个可更新的查询”问题的解决方法
- hibernate使用注解无法进行更新操作的解决方法
- zend framework 中使用dbadapter操作数据库的几种方法(持续更新)
- sql server 还原数据库时提示数据库正在使用,无法进行操作的解决方法
- sql2005还原数据库时提示:数据库正在使用,无法进行操作的解决方法
- 关于SubSonic3.0插件使用Json反序列化获得的实体进行更新操作时,只能执行添加而不能执行修改(编辑)操作的处理
- objective-c中对象所有权的内存管理(关于set,get方法),以及如何使用@property来进行简易操作(九)
- objective-c中对象所有权的内存管理(关于set,get方法),以及如何使用@property来进行简易操作