hibernate的抓取策略

抓取策略主要是指获取连接对象的策略
1.基于xml的抓取策略
基于xml抓取Many-to-one

//many-to-one 默认情况下,使用的是延时加载,在使用到classroom时才会加载所以,此时会发出sql加载classroom
public void testFetch(){
        Session session=null;
        try {
            //此时会发三条语句
            session=HibernateUtil.openSession();
            Student student=(Student) session.load(Student.class, 1);
                        System.out.println(student.getName()+"班级:"+student.getClassroom().getName()+"专业:"+student.getClassroom().getSpecial().getName());

        } catch (Exception e) {
            e.printStackTrace();
        }
    }

设置fetch=join后,就会只发一条sql,通过join来完成连接查询,
设置代码如下:

    <many-to-one name="special" column="spe_id" fetch="join"/>

但是fetch=join无法抓取hql中的list,如果需要抓取hql中的list有两种方式:
1.设置one的一端对象的batch-size,此时会通过in加载多条数据,在抓取classroom的时候会一次抓取10条classroom的记录

<class name="ClassRoom" table="t_class" batch-size="10">
        <id name="id">
            <generator class="native" />
        </id>
        <property name="name" />

2.在hql语句中写预抓取(join fetch)
特别注意:使用join fetch查询不支持count(*)的查询

    public void test10(){
        Session session=null;
        try {
            session=HibernateUtil.openSession();
            List<Student> stus=session.createQuery("select stu from Student stu join fetch stu.classroom ")
            .setParameter(0,"%张%")
            .setParameterList("ids", new Integer[]{1,2})
            .list();
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值