zoukankan      html  css  js  c++  java
  • 35hibernate_fetch_6_batch_size

    hibernate抓取策略,,batch-szie在<class>上的应用

    batch-size属性,可以批量加载实体类,参见:Classes.hbm.xml
    <class name="Classes" table="t_classes" batch-size="3">
    =============================================================================================
    public void testFetch1() {
            Session session = null;
            try {
                session = HibernateUtils.getSession();
                session.beginTransaction();
                
                List students = session.createQuery("select s from Student s where s.id in(:ids)")
                       .setParameterList("ids"new Object[]{1112131415161718191})
                       .list();
                for (Iterator iter=students.iterator(); iter.hasNext();) {
                    Student  student = (Student)iter.next();
                    System.out.println("student.name=" + student.getName());
                    System.out.println("classes.name=" + student.getClasses().getName());
                }
                session.getTransaction().commit();
            }catch(Exception e) {
                e.printStackTrace();
                session.getTransaction().rollback();
            }finally {
                HibernateUtils.closeSession(session);
            }
        }
    配置batch-size="3"时:<class name="Classes" table="t_classes" batch-size="3">
    Hibernate: select student0_.id as id1_, student0_.name as name1_, student0_.classesid as classesid1_ from t_student student0_ where student0_.id in (? , ? , ? , ? , ? , ? , ? , ? , ? , ?)
    student.name=班级0的学生0
    Hibernate: select classes0_.id as id0_0_, classes0_.name as name0_0_ from t_classes classes0_ where classes0_.id in (?, ?, ?)
    classes.name=班级0
    student.name=班级1的学生0
    classes.name=班级1
    student.name=班级2的学生0
    classes.name=班级2
    student.name=班级3的学生0
    Hibernate: select classes0_.id as id0_0_, classes0_.name as name0_0_ from t_classes classes0_ where classes0_.id in (?, ?, ?)
    classes.name=班级3
    student.name=班级4的学生0
    classes.name=班级4
    student.name=班级5的学生0
    classes.name=班级5
    student.name=班级6的学生0
    Hibernate: select classes0_.id as id0_0_, classes0_.name as name0_0_ from t_classes classes0_ where classes0_.id in (?, ?, ?)
    classes.name=班级6
    student.name=班级7的学生0
    classes.name=班级7
    student.name=班级8的学生0
    classes.name=班级8
    student.name=班级9的学生0
    Hibernate: select classes0_.id as id0_0_, classes0_.name as name0_0_ from t_classes classes0_ where classes0_.id=?
    classes.name=班级9

    ===============================================================================================
    什么都不配置时:发10条<class name="Classes" table="t_classes">
    Hibernate: select student0_.id as id1_, student0_.name as name1_, student0_.classesid as classesid1_ from t_student student0_ where student0_.id in (? , ? , ? , ? , ? , ? , ? , ? , ? , ?)
    student.name=班级0的学生0
    Hibernate: select classes0_.id as id0_0_, classes0_.name as name0_0_ from t_classes classes0_ where classes0_.id=?
    classes.name=班级0
    student.name=班级1的学生0
    Hibernate: select classes0_.id as id0_0_, classes0_.name as name0_0_ from t_classes classes0_ where classes0_.id=?
    classes.name=班级1
    student.name=班级2的学生0
    Hibernate: select classes0_.id as id0_0_, classes0_.name as name0_0_ from t_classes classes0_ where classes0_.id=?
    classes.name=班级2
    student.name=班级3的学生0
    Hibernate: select classes0_.id as id0_0_, classes0_.name as name0_0_ from t_classes classes0_ where classes0_.id=?
    classes.name=班级3
    student.name=班级4的学生0
    Hibernate: select classes0_.id as id0_0_, classes0_.name as name0_0_ from t_classes classes0_ where classes0_.id=?
    classes.name=班级4
    student.name=班级5的学生0
    Hibernate: select classes0_.id as id0_0_, classes0_.name as name0_0_ from t_classes classes0_ where classes0_.id=?
    classes.name=班级5
    student.name=班级6的学生0
    Hibernate: select classes0_.id as id0_0_, classes0_.name as name0_0_ from t_classes classes0_ where classes0_.id=?
    classes.name=班级6
    student.name=班级7的学生0
    Hibernate: select classes0_.id as id0_0_, classes0_.name as name0_0_ from t_classes classes0_ where classes0_.id=?
    classes.name=班级7
    student.name=班级8的学生0
    Hibernate: select classes0_.id as id0_0_, classes0_.name as name0_0_ from t_classes classes0_ where classes0_.id=?
    classes.name=班级8
    student.name=班级9的学生0
    Hibernate: select classes0_.id as id0_0_, classes0_.name as name0_0_ from t_classes classes0_ where classes0_.id=?
    classes.name=班级9
    =============================================================================================
    配置batch-size="5"时:发2条
    <class name="Classes" table="t_classes" batch-size="5">
    Hibernate: select student0_.id as id1_, student0_.name as name1_, student0_.classesid as classesid1_ from t_student student0_ where student0_.id in (? , ? , ? , ? , ? , ? , ? , ? , ? , ?)
    student.name=班级0的学生0
    Hibernate: select classes0_.id as id0_0_, classes0_.name as name0_0_ from t_classes classes0_ where classes0_.id in (?, ?, ?, ?, ?)
    classes.name=班级0
    student.name=班级1的学生0
    classes.name=班级1
    student.name=班级2的学生0
    classes.name=班级2
    student.name=班级3的学生0
    classes.name=班级3
    student.name=班级4的学生0
    classes.name=班级4
    student.name=班级5的学生0
    Hibernate: select classes0_.id as id0_0_, classes0_.name as name0_0_ from t_classes classes0_ where classes0_.id in (?, ?, ?, ?, ?)
    classes.name=班级5
    student.name=班级6的学生0
    classes.name=班级6
    student.name=班级7的学生0
    classes.name=班级7
    student.name=班级8的学生0
    classes.name=班级8
    student.name=班级9的学生0
    classes.name=班级9
  • 相关阅读:
    田忌赛马 题解
    亚历山大的丢番图方程 题解
    zhx's contest题解
    芝麻OI比赛T7edges题解
    CSP-J2020游记
    Linux shell 学习笔记(五)
    Linux shell 学习笔记(四)
    Linux shell 学习笔记(三)
    Linux shell 学习笔记(二)
    Oracle并发
  • 原文地址:https://www.cnblogs.com/alamps/p/2635695.html
Copyright © 2011-2022 走看看