Hibernate三种状态:瞬时状态、持久化状态、离线状态
三种状态及相互转化
瞬时状态(transient):刚new出来一个对象,还没有被保存到数据库中
持久化状态(persistent):已经被保存到数据库中或刚从数据库中取得
离线状态(detached):数据库中有,但是session中不存在该对象

方法的代码实例(下面代码1-8是连贯的,但由于需要分条说明,因此拆开)
(1) save():把一个对象从[瞬时状态]转换成[持久化状态](要注意DB里没有ID重复的该条数据)。
SessionFactory sessionFactory = SessionFactoryBuilder.getInstance();
Session session = sessionFactory.openSession();
session.beginTransaction();
TestUser user1 = new TestUser("1", "name1"); // user变成瞬时状态
session.save(user1); // user变成持久化状态
session.getTransaction().commit(); // 发出insert语句
session.close();
// [输出LOG]
// Hibernate: insert into test_user (user_name, user_id) values (?, ?)
(2) update():把一个对象从[瞬时状态]转换成[持久化状态](要注意DB里要有ID重复的该条数据)。
session = sessionFactory.openSession();
session.beginTransaction();
TestUser user2 = new TestUser("1", "name1-update(2)");
session.update(user2);
session.getTransaction().commit();
session.close();
// [输出LOG]
// Hibernate: update test_user set user_name=? where user_id=?
(3) saveOrUpdate():当(1)(2)中不确定DB里是否有ID重复的该条数据时可以用saveOrUpdate()。
session = sessionFactory.openSession();
session.beginTransaction();
TestUser user3 = new TestUser("1", "name1-update(3)");
TestUser user4 = new TestUser("2", "name2");
session.saveOrUpdate(user3);
session.saveOrUpdate(user4);
session.getTransaction().commit();
session.close();
// [输出LOG]
// Hibernate: select testuser_.user_id, testuser_.user_name as user_nam2_0_ from test_user testuser_ where testuser_.user_id=?
// Hibernate: select testuser_.user_id, testuser_.user_name as user_nam2_0_ from test_user testuser_ where testuser_.user_id=?
// Hibernate: insert into test_user (user_name, user_id) values (?, ?)
// Hibernate: update test_user set user_name=? where user_id=?
(4) 一个commit内先save再多次update,commit时只会做一次insert和一次update。
session = sessionFactory.openSession();
session.beginTransaction();
TestUser user5 = new TestUser("3", "name3");
session.save(user5);
user5.setUserName("name3-update(4)-1");
session.update(user5); // 该条语句可省略
user5.setUserName("name3-update(4)-2");
session.update(user5); // 该条语句可省略
user5.setUserName("name3-update(4)");
// 在调用了save方法后,此时user已经是持久化对象了,被保存在了session缓存当中,
// 这时user又重新修改了属性值,那么在commit时,此时hibernate对象就会拿当前这个user对象和保存在session缓存中的user对象进行比较,
// 如果两个对象相同,则不会发送update语句,否则,如果两个对象不同,则会发出update语句。所以无论多少次update,最终只会发送一次update语句。
session.getTransaction().commit();
session.close();
// [输出LOG]
// Hibernate: insert into test_user (user_name, user_id) values (?, ?)
// Hibernate: update test_user set user_name=? where user_id=?
(5) get();load();list();uniqueResult();等查询语句,如果数据库中有该对象,则该对象也变成了[持久化状态],被session所托管。
session = sessionFactory.openSession();
session.beginTransaction();
TestUser user6 = session.get(TestUser.class, "1");
TestUser user7 = session.load(TestUser.class, "2");
@SuppressWarnings("unchecked")
List<TestUser> user8List = session.createQuery("from TestUser").list();
user6.setUserName("name1-update(5)");
user7.setUserName("name2-update(5)");
user8List.get(2).setUserName("name3-update(5)");
session.getTransaction().commit();
session.close();
// [输出LOG]
// Hibernate: select testuser0_.user_id as user_id1_0_0_, testuser0_.user_name as user_nam2_0_0_ from test_user testuser0_ where testuser0_.user_id=?
// Nov 17, 2017 3:14:20 PM org.hibernate.hql.internal.QueryTranslatorFactoryInitiator initiateService
// INFO: HHH000397: Using ASTQueryTranslatorFactory
// Hibernate: select testuser0_.user_id as user_id1_0_, testuser0_.user_name as user_nam2_0_ from test_user testuser0_
// Hibernate: update test_user set user_name=? where user_id=?
// Hibernate: update test_user set user_name=? where user_id=?
// Hibernate: update test_user set user_name=? where user_id=?
(6) evict();clear();close();将session的缓存对象清空evict()清除指定对象;clear()&close()清除所有对象。它们使对象从[持久化状态]变成[离线状态]。
session = sessionFactory.openSession();
session.beginTransaction();
TestUser user9 = session.get(TestUser.class, "1");
TestUser user10 = session.get(TestUser.class, "2");
user9.setUserName("name1-update(6)");
user10.setUserName("name2-update(6)");
session.evict(user9);
session.clear();
session.getTransaction().commit();
session.close();
// [输出LOG]
// Hibernate: select testuser0_.user_id as user_id1_0_0_, testuser0_.user_name as user_nam2_0_0_ from test_user testuser0_ where testuser0_.user_id=?
// Hibernate: select testuser0_.user_id as user_id1_0_0_, testuser0_.user_name as user_nam2_0_0_ from test_user testuser0_ where testuser0_.user_id=?
(7) update();saveOrUpdate();使对象从[离线状态]转成[持久化状态]。
session = sessionFactory.openSession();
session.beginTransaction();
TestUser user11 = session.get(TestUser.class, "1"); // 持久化状态
user11.setUserName("name1-update(7)");
session.evict(user11); // 离线状态
session.update(user11); // 持久化状态
session.getTransaction().commit();
session.close();
// [输出LOG]
// Hibernate: select testuser0_.user_id as user_id1_0_0_, testuser0_.user_name as user_nam2_0_0_ from test_user testuser0_ where testuser0_.user_id=?
// Hibernate: update test_user set user_name=? where user_id=?
(8) delete();从[瞬时状态]和[持久化状态]都可以删除。
session = sessionFactory.openSession();
session.beginTransaction();
TestUser user12 = new TestUser("1", "name1");
session.delete(user12);
TestUser user13 = session.get(TestUser.class, "2");
session.delete(user13);
session.getTransaction().commit();
session.close();
// [输出LOG]
// Hibernate: select testuser_.user_id, testuser_.user_name as user_nam2_0_ from test_user testuser_ where testuser_.user_id=?
// Hibernate: select testuser0_.user_id as user_id1_0_0_, testuser0_.user_name as user_nam2_0_0_ from test_user testuser0_ where testuser0_.user_id=?
// Hibernate: delete from test_user where user_id=?
// Hibernate: delete from test_user where user_id=?
Hibernate三种状态:瞬时状态、持久化状态、离线状态的更多相关文章
- 简单理解Hibernate三种状态的概念及互相转化
本文描述了Hibernate三种状态的概念及互相转化.Java对象的生命周期中有三种状态,而且互相转化.它们分别是临时状态,持久化状态,以及游离状态. AD:WOT2015 互联网运维与开发者大会 热 ...
- [转]hibernate三种状态详解
本文来自 http://blog.sina.com.cn/u/2924525911 hibernate 三种状态详解 (2013-04-15 21:24:23) 转载▼ 分类: hibernate ...
- hibernate三种状态
转自:http://www.cnblogs.com/xiaoluo501395377/p/3380270.html 学过hibernate的人都可能都知道hibernate有三种状态,transien ...
- hibernate 三种状态的转换
一.遇到的神奇的事情 使用jpa操作数据库,当我使用findAll()方法查处一个List的对象后,给对这个list的实体进行了一些操作,并没有调用update 或者 saveOrUpdate方法,更 ...
- SSH框架之-hibernate 三种状态的转换
一.遇到的神奇的事情 使用jpa操作数据库,当我使用findAll()方法查处一个List的对象后,给对这个list的实体进行了一些操作,并没有调用update 或者 saveOrUpdate方法,更 ...
- Hibernate三种状态,缓存,以及update更新问题
一. Hibernate中对象的三种状态 1. 瞬时状态(transient) 当我们通过Java的new关键字来生成一个实体对象时,这时这个实体对象就处于自由状态,此时该对象只是通过JVM获得了一块 ...
- Hibernate——三种状态的理解
在Hibernate中有三种状态,对这三种状态的深入的理解,能够更好的理解Hibernate的执行机制. 在整个Hibernate中这三种状态是能够进行转换的. 1.Transient Object( ...
- Hibernate三种状态的转换
hibernate的状态 hibernate的各种保存方式的区(save,persist,update,saveOrUpdte,merge,flush,lock)及 对象的三种状态 hibernate ...
- Hibernate三种状态的区分,以及save,update,saveOrUpdate,merge等的使用 引自http://www.blogjava.net/TiGERTiAN/archive/2008/10/25/236519.html
Hibernate的对象有3种状态,分别为:瞬时态(Transient). 持久态(Persistent).脱管态(Detached).处于持久态的对象也称为PO(Persistence Object ...
随机推荐
- anguar @input绑定的属性变化
Intercept @Input property change in Angular Bharat TiwariFollow Mar 15, 2018 this post is good for A ...
- pip报错以及指向错误
在终端中输入无论是pip3 -V或是pip -V都指向python3 如下图所示: 然后在卸载或更新pip 时都出现了报错: 就是卸载也卸不了更新也更不了 解决报错: Traceback (most ...
- [转载]springboot--常用注解--@configration、@Bean
springboot--常用注解--@configration.@Bean @Target({ElementType.TYPE}) @Retention(RetentionPolicy.RUNTIME ...
- zabbix内存溢出解决方法
1406:20180802:183248.783 __mem_malloc: skipped 0 asked 48 skip_min 4294967295 skip_max 0 1406:201808 ...
- 如何定义搜索面板的过滤器?DevExpress WPF超easy
DevExpress广泛应用于ECM企业内容管理. 成本管控.进程监督.生产调度,在企业/政务信息化管理中占据一席重要之地.通过DevExpress WPF Controls,您能创建有着强大互动功能 ...
- redis常见问题(转)
常见问题:1.为什么使用redis(一)性能我们在碰到需要执行耗时特别久,且结果不频繁变动的SQL,就特别适合将运行结果放入缓存.这样,后面的请求就去缓存中读取,使得请求能够迅速响应.(二)并发在大并 ...
- 立即执行函数与For. . .in语句
㈠立即执行函数 ⑴定义:在函数定义完,立即被调用,这样的函数叫做立即执行函数 ⑵语法:函数对象() ⑶注意:立即执行函数往往只会执行一次 ⑷示例1: (function(){ alert(" ...
- 封装Vue组件的一些技巧
封装Vue组件的一些技巧 本文同步在个人博客shymean.com上,欢迎关注 写Vue有很长一段时间了,除了常规的业务开发之外,也应该思考和反思一下封装组件的正确方式.以弹窗组件为例,一种实现是在需 ...
- ueditor上粘贴从word中copy的图片和文字
图片的复制无非有两种方法,一种是图片直接上传到服务器,另外一种转换成二进制流的base64码目前限chrome浏览器使用首先以um-editor的二进制流保存为例:打开umeditor.js,找到UM ...
- AT3912 Antennas on Tree
AT3912 Antennas on Tree %%zzt 只能考虑性质了. 把最后选择的k个点的连通块求出来,连通块内部的点表示都是互异的 连通块外部的点只能形成若干条链,并且这k个点的每一个最多与 ...