Hibernate的四种抓取策略
Hibernate的四种抓取策略
猪刚烈 发表于3年前
Hibernate的四种抓取策略
  • 发表于 3年前
  • 阅读 7
  • 收藏 0
  • 点赞 0
  • 评论 0

subselect fetching是hibernate特有的抓取策略。它在抓取时机上有些介于lazy和eager之间(只是这样说,它实际上是配合lazy的一种抓取策略)。 一方面,它是在集合第一次被访问时才进行抓取,这有一些lazy的意味。但同时它的确预先抓取了一些“额外”的数据出来,而这些数据是要在后面使用到的,从而避免了多次select,这又有些eager的意味。 subselect比select智能的地方在于,它会把上次load出来的包含这个集合的结果集做为子查询来查所有的集合。之所以说这种方式适合用来抓取平行集合是因为:在此之前集合从属对象一定已经抓取出来了。


subselect fetching是抓取平行集合最好的方案。对于平行集合,由于笛卡尔积的问题,join fetch不能考虑了,如果使用select fetch,又有可能出现n+1次查询问题,最好的方案就是subselect fetch了。但是尽管如此,subselect fetching还是不能很好的解决抓取平行集合的问题。原因就在于它是一种全局抓取策略。当我们想要抓取平行集合元素所依赖的其他对象时就没有使用动态抓取的机会了。这确实是一个问题。目前我还在寻找解决方法。其中一个构想中的方案是:通过二级缓存,分步地加载平行集合,让最终返回是实体是完全抓取好的。

共有 人打赏支持
粉丝 22
博文 708
码字总数 110
作品 1
×
猪刚烈
如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
* 金额(元)
¥1 ¥5 ¥10 ¥20 其他金额
打赏人
留言
* 支付类型
微信扫码支付
打赏金额:
已支付成功
打赏金额: