一,首先hibernate中对象的状态有三种:瞬态、游离态和持久态,三种状态转化的方法都是通过session来调用,瞬态到持久态的方法有save()、saveOrUpdate()、get()、load();持久态到瞬态的方法有delete();游离态到持久态的方法有update()、saveOrUpdate()、lock();持久态到游离态的方法有:session.close()、session.evict()、session.clear()。

二,Hibernate的状态

  hibernate的各种保存方式的区(save,persist,update,saveOrUpdte,merge,flush,lock)及 对象的三种状态

  hibernate的保存

  hibernate对于对象的保存提供了太多的方法,他们之间有很多不同,这里细说一下,以便区别。

  一、预备知识

  在所有之前,说明一下,对于hibernate,它的对象有三种状态,transient、persistent、detached

  下边是常见的翻译办法:

  transient:瞬时态或者临时态

  (new DeptPo(1,”行政部”,20,”行政相关”),该po的实例和session没有关联,该po的实例处于transient)

  persistent:持久化状态

  (和数据库中记录想影射的Po实例,它的状态是persistent, 通过get和load等得到的对象都是persistent)

  detached:脱管状态或者游离态

  (1)当通过get或load方法得到的po对象它们都处于persistent,但如果执行delete(po)时(但不能执行事务),该 po状态就处于detached, (表示和session脱离关联),因delete而变成游离态可以通过save或saveOrUpdate()变成持久态

  (2)当把session关闭时,session缓存中的persistent的po对象也变成detached

  因关闭session而变成游离态的可以通过lock、save、update变成持久态

  持久态实例可以通过调用 delete()变成脱管状态。

  通过get()或load()方法得到的实例都是持久化状态的。

  脱管状态的实例可以通过调用lock()或者replicate()进行持久化。

  save()和persist()将会引发SQL的INSERT,delete()会引发SQLDELETE,

  而update()或merge()会引发SQL UPDATE。对持久化(persistent)实例的修改在刷新提交的时候会被检测到,它也会引起SQL UPDATE。

  saveOrUpdate()或者replicate()会引发SQLINSERT或者UPDATE

  二、save 和update区别

  把这一对放在第一位的原因是因为这一对是最常用的。

  save的作用是把一个新的对象保存

  update是把一个脱管状态的对象或自由态对象(一定要和一个记录对应)更新到数据库

  三、update 和saveOrUpdate区别

  这个是比较好理解的,顾名思义,saveOrUpdate基本上就是合成了save和update,而update只是update;引用hibernate reference中的一段话来解释他们的使用场合和区别

  通常下面的场景会使用update()或saveOrUpdate():

  程序在第一个session中加载对象,接着把session关闭

  该对象被传递到表现层

  对象发生了一些改动

  该对象被返回到业务逻辑层最终到持久层

  程序创建第二session调用第二个session的update()方法持久这些改动

  saveOrUpdate(po)做下面的事:

  如果该po对象已经在本session中持久化了,在本session中执行saveOrUpdate不做任何事

  如果savaOrUpdate(新po)与另一个与本session关联的po对象拥有相同的持久化标识(identifier),抛出一个异常

  org.hibernate.NonUniqueObjectException: a different object with the same identifier value was already associated with the session: [org.itfuture.www.po.Xtyhb#5]

  saveOrUpdate如果对象没有持久化标识(identifier)属性,对其调用save() ,否则update() 这个对象

  四、persist和save区别

  这个是最迷离的一对,表面上看起来使用哪个都行,在hibernate reference文档中也没有明确的区分他们.

  这里给出一个明确的区分。(可以跟进src看一下,虽然实现步骤类似,但是还是有细微的差别)

  主要内容区别:

  1,persist把一个瞬态的实例持久化,但是并"不保证"标识符(identifier主键对应的属性)被立刻填入到持久化实例中,标识符的填入可能被推迟到flush的时候。

  2,save, 把一个瞬态的实例持久化标识符,及时的产生,它要返回标识符,所以它会立即执行Sql insert

  五、saveOrUpdate,merge和update区别

  比较update和merge

  update的作用上边说了,这里说一下merge的

  如果session中存在相同持久化标识(identifier)的实例,用用户给出的对象覆盖session已有的持久实例

  (1)当我们使用update的时候,执行完成后,会抛出异常

  (2)但当我们使用merge的时候,把处理自由态的po对象A的属性copy到session当中处于持久态的po的属性中,执行完成后原来是持久状态还是持久态,而我们提供的A还是自由态

  六、flush和update区别

  这两个的区别好理解

  update操作的是在自由态或脱管状态(因session的关闭而处于脱管状态)的对象//updateSQL

  而flush是操作的在持久状态的对象。

  默认情况下,一个持久状态的对象的改动(包含set容器)是不需要update的,只要你更改了对象的值,等待hibernate flush就自动更新或保存到数据库了。hibernate flush发生在以下几种情况中:

  1, 调用某些查询的和手动flush(),session的关闭、SessionFactory关闭结合

  get()一个对象,把对象的属性进行改变,把资源关闭。

  2,transaction commit的时候(包含了flush)

  七、lock和update区别

  update是把一个已经更改过的脱管状态的对象变成持久状态

  lock是把一个没有更改过的脱管状态的对象变成持久状态(针对的是因Session的关闭而处于脱管状态的po对象(2),不能针对因delete而处于脱管状态的po对象)

  对应更改一个记录的内容,两个的操作不同:

  update的操作步骤是:

  (1)属性改动后的脱管的对象的修改->调用update

  lock的操作步骤是:

  (2)调用lock把未修改的对象从脱管状态变成持久状态-->更改持久状态的对象的内容-->等待flush或者手动flush

  八、clear和evcit的区别

  clear完整的清除session缓存

  evcit(obj)把某个持久化对象从session的缓存中清空。

  session.lock(xtyhb,LockMode.NONE);//表示直接到缓存中去找变成持久态的对象

  session.lock(xtyhb,LockMode.READ);//先通过ID读数据库该记录的ID看是否有该记录,如果有接着到缓存中去找变成持久态的对象


在Hibernate中,对象有三种状态:临时状态、持久状态和游离状态。

也叫:瞬时态(Transient)、持久态(Persistent)、脱管态(Detached)。处于持久态的对象也称为PO(Persistence Object),瞬时对象和脱管对象也称为VO(Value Object)。

临 时状态:当new一个实体对象后,这个对象处于临时状态,即这个对象只是一个保存临时数据的内存区域,如果没有变量引用这个对象,则会被jre垃圾回收机 制回收。这个对象所保存的数据与数据库没有任何关系,除非通过Session的save或者SaveOrUpdate把临时对象与数据库关联,并把数据插 入或者更新到数据库,这个对象才转换为持久对象。
例如:Emp e=new Emp();    //创建临时对象
          e.setEmpno((long) 8888);
          e.setEName("mike");
          ...
          EmpDAO d=new EmpDAO();
          d.save(e);      //持久化
          ...

持久状态:持久化对象的实例在数据库中有对应的记录,并拥有一个持久化表示(ID)。对持久化对象进行delete操作后,数据库中对应的记录将被删除,那么持久化对象与数据库记录不再存在对应关系,持久化对象变成临时状态。
    持久化对象被修改变更后,不会马上同步到数据库,知道数据库事务提交。在同步之前,持久化对象是脏的(Dirty)。
例如:
          Emp e=new Emp(); //创建了临时的对象
          EmpDAO edao= new empDAO();
          e=edao.findbyEmpno((long) 7786);    //使对象与数据库记录对应,从而持久化
          e.setEname("新的名字");                     //修改了持久化对象,使之处于 Dirty
          ......
          edao.saveorupdate(e);                      //保存,但是仍然 Dirty
          tran.commit();                                     //提交,实现与数据库同步,不再Dirty
          ......

游离状态:当Session进行了Close、Clear或者evict后,持久化对象虽然拥有持久化标识符和与数据库对应记录一致的值,但是因为 会话已经消失,对象不在持久化管理之内,所以处于游离状态(也叫:脱管状态)。游离状态的对象与临时状态对象是十分相似的,只是它还含有持久化标识。

瞬时态 
        由new命令开辟内存空间的java对象, 
       eg. Person person = new Person("xxx", "xx"); 
        如果没有变量对该对象进行引用,它将被java虚拟机回收。 
         瞬时对象在内存孤立存在,它是携带信息的载体,不和数据库的数据有任何关联关系,在Hibernate中,可通过session的save()或 saveOrUpdate()方法将瞬时对象与数据库相关联,并将数据对应的插入数据库中,此时该瞬时对象转变成持久化对象。
持久态 
        处于该状态的对象在数据库中具有对应的记录,并拥有一个持久化标识。如果是用hibernate的delete()方法,对应的持久对象就变成瞬时对象,因数据库中的对应数据已被删除,该对象不再与数据库的记录关联。
       当一个session执行close()或clear()、evict()之后,持久对象变成脱管对象,此时持久对象会变成脱管对象,此时该对象虽然具有数据库识别值,但它已不在HIbernate持久层的管理之下。
       持久对象具有如下特点: 
        1. 和session实例关联; 
       2. 在数据库中有与之关联的记录。 
脱管态 
        当与某持久对象关联的session被关闭后,该持久对象转变为脱管对象。当脱管对象被重新关联到session上时,并再次转变成持久对象。 
       脱管对象拥有数据库的识别值,可通过update()、saveOrUpdate()等方法,转变成持久对象。 
       脱管对象具有如下特点: 
       1. 本质上与瞬时对象相同,在没有任何变量引用它时,JVM会在适当的时候将它回收; 
        2.   比瞬时对象多了一个数据库记录标识值。

hibernate中对象的状态有三种相关推荐

  1. hibernate中对象的3种状态----瞬时态、持久态、脱管态

    转载: http://www.blogjava.net/amigoxie/archive/2007/02/11/99342.html Hibernate的对象有3种状态,分别为:瞬时态(Transie ...

  2. hibernate中对象的三种状态瞬时态,持久态,游离态区分

     1.瞬时态. hibernate中什么时候的对象为瞬时态呢,当我们new 一个对象时,还没有save时,它就是瞬时态的,当我们delete一个对象时,它也是瞬时态了,因为此时,他们在数据库中没有对应 ...

  3. hibernate中对象的3种状态(瞬态,持久态,游离态)

    瞬态: 如:Product p=new Product(); //瞬态的对象, new 做查询操作 持久态:save delete p.setPname() 将对象从瞬间变成持久态 做修改的动作 可以 ...

  4. Hibernate 中对象 set 属性时自动保存入库的问题

    背景 在某个项目中,通过 Heibernate 查出某个对象后,对属性进行了 set 操作,并没有进行 update 操作,但是在数据中自动保存了. 显然这并不是我想要的,我只是想 set 一下属性, ...

  5. Hibernate持久化对象的状态:瞬时状态、持久化状态、托管状态

    瞬时状态:对象由new操作符创建,但没有和session关联,也就是我们刚刚创建的对象,还没有保存到数据库中去 持久化状态:对象被保存到数据库中去了,并且还与session有关联 托管状态:对象已经被 ...

  6. C#中对象的销毁有三种方式Finalize,Dispose,GC。

    为什么80%的码农都做不了架构师?>>>    1.Finalize方法(C#中是析构函数,以下称析构函数)是用于释放非托管资源的,而托管资源会由GC自动回收.所以,我们也可以这样来 ...

  7. java session 生命周期_java之hibernate之session中对象的生命周期

    1. session是用来执行对象的crud操作,并且session是对象事务工厂.session是线程级别的,所以生命周期比较短. 2.session中对象的生命周期图: 3.session中对象的 ...

  8. ORM进阶之Hibernate中关系映射

    ORM进阶之 ORM简介 ORM进阶之Hibernate简介及框架搭 ORM进阶之Hibernate的三大对象 ORM进阶之Hibernate中对象的三大状态解析 ORM进阶之Hibernate中一对 ...

  9. Hibernate中Session的清理与清空

    Session清理 调用session.flush()方法 Session清空 调用session.clear()方法. 清理缓存 是指按照缓存中对象的状态的变化,来同步更新数据库 但不清空缓存 清空 ...

最新文章

  1. 51单片机怎么学啊?有推荐的网课和书籍么?
  2. Insightface项目爬坑指南+使用本地数据集训练流程(MXNET版)
  3. CSS中常见的长度单位
  4. android应用程序开发_深圳app开发公司:跨平台应用程序开发工具有哪些?
  5. 今时今日,C还适合当下之所需么?
  6. Java IDE 的困惑
  7. python ax.imshow_python – Matplotlib imshow / matshow在情节上显...
  8. AttributeError: module 'cv2' has no attribute 'imread'
  9. yii 使用 有赞sdk_有赞 App 动态化配置中心实践
  10. pytorch_CNN实现文本情感分类
  11. 用matplotlib中的scatter方法画散点图
  12. 黑马程序员--'1封感人的来信—穷的只剩下梦想,1个黑马程序员的追梦之旅
  13. android输入法剪切板历史记录,干货分享 讯飞输入法剪切板使用技巧知多少
  14. 刀具半径补偿 c语言,C语言程序实现数控加工刀具半径补偿原理与坐标计算.pdf...
  15. Java实现邮件抓取(亲测126,163,新浪都可以抓取到)
  16. 如何给Mac挑选外接显示器?苹果外接显示器选购指南
  17. 【python逆向一把梭】pyinstaller打包的exe逆向一把梭
  18. 基于C语言的网络电子词典
  19. 官能团醛化改性修饰药物的制备
  20. vs2010 玩转金山界面库 (2) 应用基础

热门文章

  1. 开发你自己的Android 授权管理器 (AccountManager的使用以及应用场景)
  2. JavaScript五子棋
  3. jqGrid可编辑模式下 单元格内容不能复制处理
  4. 什么是大数据开发?大数据开发要学什么?一个Java转行过程和经历
  5. 前端低代码平台腾讯云微搭使用文档
  6. JavaScript实现H5游戏断线自动重连的技术
  7. bp神经网络原理 实现过程,bp神经网络的应用案例
  8. wdnas群晖nas_WD 西部数据 伪NAS折腾记 篇三:WD 西部数据 MyCloud安装黑群晖教程
  9. 最常用的65条正则表达式
  10. Spring Boot 项目结构介绍