持久态对象的标志是它有id值,并且会被存入session的一级缓存。特点是对它们的操作hibernate是能够知道的并且在调用
session.flush()方法时将对它们的更新操作(如obj.setXxx()方法)同步到数据库。在调用commit()方法前会自动调用
flush()方法,用户也可以自己调用flush()方法。调用session.clear()方法会清空一级缓存,将所有的持久化对象变为脱管的,因
此调用clear()方法前一定要调用session.flush()方法,将一级缓存中的持久化对象同步到数据库。
脱管对象与瞬时对象都不在hibernate的管理中,它们的区别是脱管对象有id值,数据库中有记录和它对应,但瞬时对象没有id值也没有数据库记录和它对应。
要强调的是瞬时对象调用session.save(obj)方法后对象虽然变为持久态的,有id值,但是此时数据库中不一定有一条记录和对象对应。如果对
象的主键生成策略是“native”,那么hibernate使用数据库自身的机制生成主键(mysql是auto_increment,oracle使
用squence机制),这时只有当数据插入到数据库后才会得到它的主键,因此会在session.save(obj)方法时向数据库发送insert语
句,因此session.save(obj)后数据库中有记录和对象对应,但是如果对象的主键生成策略是“uuid”或“hilo”,这时要生成对象的
id不需要将对象插入数据库(uuid方式不需要访问数据库,根据主机IP等信息生成,hilo方式hiberhinate维护数据库中一张用于生成id
的表),这时session.save(obj)后对象有id值,但数据库中没有记录和它对应,只有调用flush()方法后才会发送insert语句,
将对象和数据库同步。
分享到:
相关推荐
hibernate对象三种状态,有详细的代码介绍三种状态,易理解,有具体代码实现,有详细备注,让你轻松理解三种状态的存在形式
hibernate中session对象的状态详解
一个关于关于Hibernate对象的状态的描述。
NULL 博文链接:https://unddone8373229.iteye.com/blog/1104797
hibernate的各种保存方式的区别以及hibernate对象的三种状态[定义].pdf
Hibernate中po对象的三种状态分析[借鉴].pdf
Hibernate对象状态以及各种保存方法的区别
hibernate对象三状态及OneToOne&OneToMany&ManyToMany讲解,代码示例,数据库示例!非常全面
站在持久化的角度。Hibernate把对象分为4中状态。 临时状态。 持久化状态。游离状态。删除状态。
Hibernate持久化对象的生命周期 持久化对象的状态: 瞬时对象(Transient Objects)持久化对象(Persist Objects)、离线对象(Detached ...在Hibernate应用中Java对象的状态 Session的保存、更新、删除、查询方法:
05_传智播客hibernate教程_实体对象的三种状态与saveOrUpdate方法
本人在厦门邦初培训时候 使用的快速入门精简文档 ...对象的临时状态、持久状态和游离状态 用session的update()方法使游离对象转变为持久化对象。 延迟装载 迫切左外链接 HQL检索方式 QBC检索方式 本地SQL检索方式
Hibernate对象的三种状态、状态管理
Hibernate对象的状态,本文系统地分析了其中的各种状态
hibernate相关配置 对象映射关系 3种状态格式
8.3 Java对象在Hibernate持久化层的状态 8.3.1 临时对象的特征 8.3.2 持久化对象的特征 8.3.3 被删除对象的特征 8.3.4 游离对象的特征 8.4 Session接口的详细用法 8.4.1 Session的save()和persist()...
本章主要介绍关系数据库中的代理主键(不具有业务含义),接着介绍Hibernate提供的几种内置标识符生成器的用法及适用范围。 6.1 关系数据库按主键区分不同的记录 123 6.1.1 把主键定义为自动增长标识符类型 123 ...
对象-关系映射—Hibernate 培训 (中文) 目录 一、持久化层-O/R Mapping ...三、Hibernate映射申明(Mapping declaration) 四、持久化对象的状态和生命周期 五、Hibernate查询 六、Hibernate最佳实践
10.1. Hibernate对象状态(object states) 10.2. 使对象持久化 10.3. 装载对象 10.4. 查询 10.4.1. 执行查询 10.4.2. 过滤集合 10.4.3. 条件查询(Criteria queries) 10.4.4. 使用原生SQL的查询 10.5. 修改...