您的位置:首页 > 其它

Hibernate的四种抓取策略

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

subselect fetching是抓取平行集合最好的方案。对于平行集合,由于笛卡尔积的问题,join fetch不能考虑了,如果使用select fetch,又有可能出现n+1次查询问题,最好的方案就是subselect fetch了。但是尽管如此,subselect fetching还是不能很好的解决抓取平行集合的问题。原因就在于它是一种全局抓取策略。当我们想要抓取平行集合元素所依赖的其他对象时就没有使用动态抓取的机会了。这确实是一个问题。目前我还在寻找解决方法。其中一个构想中的方案是:通过二级缓存,分步地加载平行集合,让最终返回是实体是完全抓取好的。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: