博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Hibernate中Entity对象的重新加载refresh
阅读量:4178 次
发布时间:2019-05-26

本文共 686 字,大约阅读时间需要 2 分钟。

Hibernate中处于managed/persistent状态的Entity对象可以通过持久化上下文的refresh()方法,重新加载数据库中的数据。

这往往发生在持久化上下文中的Entity对象已经过时,数据库中对应的记录被其他持久化上下文修改的情况下。

Hibernate Native API示例如下:

Person person = session.byId( Person.class ).load( personId );session.doWork( connection -> {    try(Statement statement = connection.createStatement()) {        statement.executeUpdate( "UPDATE person SET name = UPPER(name)" );    }} );session.refresh( person );
JPA API示例如下:

Person person = entityManager.find( Person.class, personId );entityManager.createQuery( "update Person set name = UPPER(name)" ).executeUpdate();entityManager.refresh( person );

执行重新加载时,通常只重新加载Entity对象中的属性值;如果Entity对象的关联被声明为REFRESH,则被关联的Entity对象也将被重新加载。

转载地址:http://cilai.baihongyu.com/

你可能感兴趣的文章
sqlserver出现文件组‘PRIMARY‘已满
查看>>
Idea移除和重新导入Maven工程module
查看>>
第九篇: Spring Cloud Sleuth(Hoxton版本)
查看>>
第九篇:高可用的服务注册中心
查看>>
第十篇: Hystrix Dashboard(Hoxton版本)
查看>>
第十一篇: Turbine(Hoxton版本)
查看>>
sqlserver导入sql文件的方式
查看>>
IDEA无法登录github解决
查看>>
Spring Bean的生命周期
查看>>
mysql的通用查询日志和慢查询日志
查看>>
IDEA中设置Run Dashboard(Services)
查看>>
Mysql5.7免安装安装教程 win10
查看>>
SpringBoot属性注入的几种方式
查看>>
Idea 解决SVN冲突
查看>>
Sptingboot AOP实现多数据源切换(Hive Impala oracle)
查看>>
dynamic-datasource动态多数据源整合hive impala
查看>>
Mybatis+impala插入超过510个字符串的字段报:HIVE_PARAMETER_QUERY_DATA_TYPE_ERR_NON_SUPPORT_DATA_TYPE
查看>>
SpringBoot项目启动完成自动打开网址
查看>>
记录一下把mapper.xml文件放在java的坑
查看>>
反射的使用
查看>>