【Hibernate】Hibernate的检索策略:lazy、fetch

本文详细介绍了Hibernate的检索策略,包括立即检索和延迟检索。在类级别,延迟检索使得session.load()返回BO的代理类实例,首次访问非ID属性时执行select。一对多、多对多关联的检索策略中,lazy配置影响何时执行select查询。fetch策略如fetch=join、fetch=subselect和batch-size各有特点,fetch=join在多对一、一对一关联时会考虑连接深度。文章通过实例解析了各种检索策略的效果和使用场景。
摘要由CSDN通过智能技术生成

检索策略

1、类级别和关联级别
  可选的检索策略 默认值 受影响的检索方法
类级别 立即检索
延迟检索
延迟 Session.load()
——Session.get()/Query.list()都会立即检索
关联级别 立即检索
延迟检索
迫切左外连接检索
延迟 Session.load()/get()
Query(注意,Query会忽略xml中配置的迫切左外连接策略)
Criteria


三种检索策略

检索策略 优点 缺点 使用场景
立即检索
  • 不管对象处于持久化状态、游离状态,都可以从一个对象导航到与他关联的另一个对象
  • select语句数目多;
  • 可能加载程序不需要访问的对象,浪费内存
  • 类级别
  • 程序需要立即访问的对象
  • 使用了二级缓存
延迟检索
  • 由应用程序决定需要加载哪些对象
  • 避免立即检索的缺点
  • 如果要访问游离状态的代理类实例,则必须保证其在持久化状态时已经被初始化
  • 一对多、多对多关联时
  • 程序不需要立即访问的对象
迫切
左外连接
  • 不管对象处于持久化状态、游离状态,都可以从一个对象导航到与他关联的另一个对象
  • select语句数目少
  • 复杂的表连接会影响性能;
  • 可能加载程序不需要访问的对象,浪费内存
  • 多对一、一对一关联
  • 程序需要立即访问的对象
  • 数据库系统具有良好的表连接性能



2、lazy与fetch
  作用 类级别 一对多关联级别<set> 多对一关联级别<many-to-one>
lazy 决定被初始化的时机
  • true:延迟检索(default)
  • false:立即检索
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值