ORM框架Hibernate (二) 持久化对象的三种状态分析

ORM框架Hibernate (二) 持久化对象的三种状态分析

  1. 引入
    1. 在解压Hibernate有好几十兆就感觉这比Struts大多了,应该比Struts要深奥一些果然是这样,不过如果你看了这篇文章,你也会理解的。
    2. 这里先不说对象的状态,本来对象挺简单的Hibernate又把对象分了三种状态,初次让人看了有点头晕的感觉怎么这么复杂?
    3. 通过看了一些资料体会是不应该先理解各种状态以及他们的用法,而应该先重点理解一下Hibernate里面的session缓存机制,如果对session理解了自然而然的就懂了对象的状态。
    4. Hibernatesession并不是通常用的那个会话session,此session非彼session
  1. Session机制
    1. Hibernate中加入session是为了减少访问数据库频率、提高数据库性能,在session中定义了Java集合,Java Collection指的是List、Map、Set等,这些都实现了Java Collection接口,他们用于存储很多的实体对象并构成了session缓存。
    1. 当像Java对象被session管理时,对象会加入到sessionMap里面缓存起来,session提供了一些方法可以保证缓存与数据库状态保持同步。
      1. 例如你提交事务的时候会自动清理缓存,并更新数据库;当然你也可以手动调用flush()方法实现。
    1. 下面就出现了对象三种状态
      1. 如果一个实体对象加入到了SessionMap里,Map会保存该对象的一个引用,这个对象就会被session管理,这个时候我们就称该对象为持久化对象(Persistent)
      2. 没有被session管理的对象成为非持久化对象,非持久化又分为临时对象(Transient)和游离对象(Detached)
  1. 对象三种状态
    1. 临时状态(Transient)
      1. 说的通俗一点就是一个对象刚创建的时候,没有被其它对象引用,从对象生命周期来看刚刚创建所以数据库中也不会有它的记录。
    1. 持久化状态(Persistent)
      1. 它是关联session的对象,即被session引用了同时数据库中也存在它的记录。
    1. 游离状态(Detached)
      1. 游离对象是断开了session关联,数据库中已经它对应的数据了,由此可见,可以对象状态是与session紧密联系的。
    1. 对象的三种状态之间可以相会转换,看下面一张图
      1. ORM框架Hibernate (二) 持久化对象的三种状态分析
      1. 上图清楚的说明了各个对象之间得转化关系以及调用方法。
  1. CRUD操作
    1. HibernateCRUD是建立在对象各种状态之上的操作,它也提供了一些简单接口供我们使用,利用这些接口让我们插入、更新、分页变得很简单,以前分页需要写好几个SQL语句嵌套才能完成,如果在Hibernate中只需要调用Query接口的setFirstResult()和setMaxResults()就可以分页,很简单。
    1. 知道了对象的状态,对对象的操作也就会了,就不举例子说明怎么插入查询等,主要还是理解了一些概念。对于操作经常使用就会熟悉。
    1. 框架带来的好处还是很多的,建议多使用框架。

转载于:https://www.cnblogs.com/lilongsheng1125/p/4978569.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/110043.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • luajit缺点_luajit和lua区别

    luajit缺点_luajit和lua区别作者:paintsnow链接:https://www.zhihu.com/question/49144449/answer/123116906来源:知乎著作权归作者所有,转载请联系作者获得授权。其实我是不主张在开发时就用LuaJIT的,因为这样会把人养懒……因为JIT的强大性能,掩盖了太多代码中的低效实现,反而最后想要提升性能已经不可能了==回到正题,我的建议是,如果

  • 区块链|CAP原理[通俗易懂]

    区块链|CAP原理[通俗易懂]分布式系统(distributedsystem)正变得越来越重要,大型网站几乎都是分布式的。分布式系统的最大难点,就是各个节点的状态如何同步。CAP定理是这方面的基本定理,也是理解分布式系统的起点。一、分布式系统的三个指标ConsistencyAvailabilityPartitiontolerance它们的第一个字母分别是C、A、P。EricBrewer说,这三个指标不可能同时做到。这个结论就叫做CAP定理。二、Partitiontolerance先看Parti

  • 全面了解 Nginx 到底能做什么

    全面了解 Nginx 到底能做什么

  • bindservice startservice_函数调用流程

    bindservice startservice_函数调用流程bindService流程

  • 运行时常量池与字符串常量池_常量池是什么

    运行时常量池与字符串常量池_常量池是什么文章目录1)方法区包含哪些内容?2)运行时常量池存在什么地方?3)取消永久代后,方法区的实现?4)字符串常量池和运行时常量池究竟去了哪里?4)元空间是什么?5)关于为什么移除永久代?5)补充        我们知道在JDK1.8中取消了永久代,区而代之使用了元空间来实现方法区。话虽如此,但是关于字符串常量池和运行时常量池的模棱两可的说法一直都是争论不休的。1)方法区包含哪些内容?方法区包含哪些内容,摘录自《java虚拟机规

  • AbstractInterceptor和Interceptor的区别

    AbstractInterceptor和Interceptor的区别AbstractInterceptor实现了Interceptor接口,并且空实现了init()和destroy()方法。在使用中,如果无需实现init和destroy方法,可以直接实现AbstractInterceptor

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号