单端代理的批量抓取

查询抓取:另外发送一条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>

posted on 2011-02-20 14:21  魔战  阅读(207)  评论(0编辑  收藏  举报