抓取策略

本文介绍了在ORM框架中使用的几种批量抓取策略,包括查询抓取、连接抓取和子查询抓取等,详细解释了每种策略的工作原理及其应用场景,并探讨了如何设置批量大小来提高查询效率。

单端代理的批量抓取

查询抓取:另外发送一条select语句抓取当前对象的关联实体和集合

<many-to-one name="classes" column="classesid" fetch="select" />

连接抓取:通过在select语句使用outer join来获得对象的关联实例或关联集合

<many-to-one name="classes" column="classesid" fetch="join" />

使用join会使lazy失效

子查询抓取:另外发送一条select语句抓取在前面查询到的所有实体对象的关联集合

<set name="students"  order-by="id"  inverse="true" cascade="all"  fetch="subselect">

<key column="classesid" not-null="true"/>

<one-to-many class="Student"/>

</set>

此抓取策略表示先查询一个实体对象,然后再通过一条select语句把此实体对象相关联的对象集合查询出来。

<class name="Classes" table="t_classes" batch-size="10">

   <id name="id">

         <generator class="native"/>

   </id>

   <property name="name"/>

   <set name="students" order-by="id" inverse="true" cascade="all">

            <key column="classesid"/>

            <one-to-many class="Student"/>

    </set>

 </class>

其中属性batch-size:表示批量把数据查询出来,该实现是通过在sql语句后添加

in(?,?,?..) 函数来实现的。

batch_size还可以在Session-Factory中设置:

<property name="hibernate.jdbc.batch_size">30</property>

<property name="hibernate.jdbc.fetch_size">50</property>

转载于:https://www.cnblogs.com/jinzhengquan/archive/2011/02/20/1958998.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值