Hibernate之深入持久化对象
Hibernate是一个彻底的O/R Mapping 框架。之所以说彻底,是因为相对于其他的 框架 ,如Spring JDBC,iBatis 需要手动的管理SQL语句,Hibernate采用了完全
面向对象的方式来操作数据库。
但是当开发者需要深入的了解Hibernate底层运行时,对Hibernate的数据访问进行优化时,就需要了解Hibernate的底层SQL操作了。由于对于绝大部分的应用来说,
数据访问是一个十分巨大的,耗时的操作,因此深入Hibernate底层对应的SQL操作非常必要。
1.持久化类的要求
所有的持久化类都应该有一个无参构造器。
提供一个标识属性(Field):标识属性通常是映射数据库表的主键字段。这个属性可以叫任何名字,类型可以是基本类型,基本类型的包装类,String,或者Date。如果该数据库表使用了联合主键,那么这个标识属性可以是用户定义的一个类,这个类拥有联合主键的字段作为属性。虽然Hibernate允许使用基本类型作为标识属性的类型,但还是建议可以用基本类型时,用基本类型的包装类进行代替。
为持久化类的每个属性提供setter和getter方法: 也就是 JavaBean风格。
选择性的重写equals()和hashCode()方法:如果需要把持久化类的对象放入Set集合中(当实现关联映射时,推荐这么做),则应该为持久化类重写equals()方法和hashCode()方法。
2.持久化类的对象的状态
瞬态状态:对象由new操作符创建出来,且尚未与Hibernate Session对象进行关联,此时的持久化类的对象处于瞬态。对于瞬态状态对象的操作或者改变,不会被保存 到数据库中去。如果程序中失去了对于处于瞬态状态对象的引用,瞬态状态的对象就会被垃圾回收器销毁。通过使用Hibernate Session对象的save()方法,可以把处于瞬态状态的对象,转化为处于持久化状态的对象。
持久化状态:当一个持久化类的对象,与Hibernate Session对象进行了关联,那么这个对象就处于持久化状态了,处于持久化状态的对象在数据库中有对应的一条记录,并拥有一个持久化标示符。对于持久化状态的对象,进行任何的改动,Hibernate都会自动检测到,然后把改动后的内容写回数据库中。开发者不需要手动的执行update。
脱管状态:某个处于持久化状态的对象,由于与之关联的Hibernate Session对象的关闭,该对象就由持久化状态沦为脱管状态。如果对于处于脱管状态的对象进行了操作或者修改,而后这个对象重新被Hibernate Session对象进行关联,即重新回到了持久化状态,那么对脱管状态时期的操作不会丢失,也会被写入数据库中。
3.Hibernate Session对象改变持久化类的对象状态的方法
sess.save(Object obj) :将obj对象转化为持久化状态 返回obj对象的标识符。
sess.persist(Object obj) :将obj对象那个转化为持久化状态 返回值为 void
使用上面两个方法将一个对象转化为持久化状态 底层会生成一条insert语句
News n = sess.load(News.class , new Integer(pk));
load()方法通过指定持久化类的类对象,和标识属性值 来 返回一个持久化状态的对象 也就会数据库中一条记录。
类似的还有get()方法。
使用上面两个方法获得一个持久化状态的对象 底层会生成一条select语句
n.setTitle("Hibernate");
通过获得的持久化状态对象,然后对它进行操作 底层;会生成一条update语句
sess.update(n); 如果n对象处于脱管状态 将n对象与sess对象关联 重新回到持久化状态
sess.updateOrSave(n); 不清楚n对象现在是处于瞬态 还是脱管状态 都转化为持久化状态
sess.merge(n); 将n对象的数据改变添加到数据库中 但是n对象仍然不是持久化状态
通过上面的方法来处理脱管状态的对象
sess.delete(n) : 删除处于持久化状态的对象 持久化状态的对象对应的数据库记录会被删除
这条语句 底层会生成一条 delete语句
Hibernate之深入持久化对象的更多相关文章
- Hibernate入门5持久化对象关系和批量处理技术
Hibernate入门5持久化对象关系和批量处理技术 20131128 代码下载 链接: http://pan.baidu.com/s/1Ccuup 密码: vqlv 前言: 前面学习了Hiberna ...
- hibernate学习之持久化对象
Hibernate对其持久化对象实现了缓存管理,来提高系统性能,Hibernate支持两级缓存管理,一级缓存 是由Session提供的,因此它只存在于Session的生命周期中,是Session所内置 ...
- hibernate框架(3)---持久化对象
持久化对象 再讲持久化对象之前,我们先来理解有关session中get方法与 load方法区别: 简单总结: (1)如果你使用load方法,hibernate认为该id对应的对象(数据库记录)在数据库 ...
- 【Hibernate步步为营】--核心对象+持久对象全析(二)
上篇文章讨论了Hibernate的核心对象,在开发过程中经经常使用到的有JTA.SessionFactory.Session.JDBC,当中SessionFactory可以看做数据库的镜像,使用它可以 ...
- 2.一起来学hibernate之配置文件1与持久化对象
学框架,配置都是不可少的,有了配置,框架才知道我们想做什么,才知道如何去执行我们需要的操作! hibernate的配置文件,总体来说分为两个部分: 1.主配置文件hibernate.cfg.xml文件 ...
- Hibernate,Session方法使得java对象进入持久化状态;持久化对象特征
以下情况java对象进入持久化状态: session.save()方法把临时对象转变为持久化对象. session.load()和session.get()方法得到的对象总是处于持久化状态. sess ...
- Hibernate之Session对象的相关方法以及持久化对象的状态
一.持久化对象的状态 站在持久化的角度, Hibernate 把对象分为 4种状态: 持久化状态,临时状态,游离状态,删除状态.Session 的特定方法能使对象从一个状态转换到另一个状 ...
- hibernate中持久化对象的生命周期(三态:自由态,持久态,游离态 之间的转换)
三态的基本概念: 1, 暂时状态(Transient):也叫自由态,仅仅存在于内存中,而在数据库中没有对应数据.用new创建的对象,它没有持久化,没有处于Session中,处于此状态的对象叫暂时对象 ...
- hibernate 持久化对象的生命周期 2.1
持久化对象的生命周期 瞬态(自由态) 表示对象在内存中存在,在数据库中没有数据相关,比如刚刚new出来的一个对象 持久态 持久态指的是持久化对象处于由Hibernate管理的状态,这种状态下持久化对象 ...
随机推荐
- Css3关键帧动画
@keyframes设置动画规则,可以理解为一个剧本: 1.name动画的名字必需填写 2.可以使用百分比0%-100%或者from...to...必填内容: 3.需要变化css的样式:必需: ani ...
- 图文详解AO打印(标准模式)
一.概述 AO打印是英文Active-Online Print的简称,也称主动在线打印.打印前支持AO通讯协议的AO打印机(购买地址>>)首先通过普通网络与C-Lodop服务保持在线链 ...
- 锐动视频SDK在金融业务加密双录管理系统通用解决方案
为了更好地保障消费者的合法权益,银监会和保监会提出了要求,在银行.保险从业人员销售理财产品或代理其他机构销售产品时,同期进行录音录像,确保销售人员按程序.按规定介绍产品,以便购买者更清楚地了解产品的性 ...
- ES6学习总结二(数组的四个方法,字符串)
数组 1 map 映射 一个对一个 如:分数数组[34,56,78,99]映射为[不及格,不及格,及格,及格]; 等级数组[23,56,89]映射为 [ {name:'lmx',level:1,rol ...
- mariadb 压缩包gz安装方式
1.解压安装包tar -zxvf mariadb-5.5.56-linux-x86_64.tar.gz 2.cd support-filescp my-small.cnf /etc/my.cnf 2. ...
- 无后台应用 Stash Backend
Stash Backend 是Github上的开源项目 https://github.com/gaboratorium/stash,目的在于提供一套方便使用.方便部署的后台应用.特别适合为Web前端和 ...
- Tensorflow小技巧整理:修改张量特定元素的值
TensorFlow小技巧整理:修改张量特定元素的值 最近在做一个摘要生成的项目,过程中遇到了很多小问题,从网上查阅了许多别人解决不同问题的方法,自己也在旁边开了个jupyter notebook搞些 ...
- Spark Streaming高级特性在NDCG计算实践
从storm到spark streaming,再到flink,流式计算得到长足发展, 依托于spark平台的spark streaming走出了一条自己的路,其借鉴了spark批处理架构,通过批处理方 ...
- push_back和emplace_back的区别
emplace_back能就地通过参数构造对象,不需要拷贝或者移动内存,相比push_back能更好地避免内存的拷贝与移动,使容器插入元素的性能得到进一步提升.在大多数情况下应该优先使用emplace ...
- 笔记:Maven 仓库和插件配置本机私服
通过配置POM中的配置仓库和插件仓库,只在当前项目生效,而实际应用中,我们希望通过一次配置就能让本机所有的Maven项目都使用自己的Maven私服,这个时候我们需要配置 settings.xml文件, ...