导航

Hibernate 延迟加载

Posted on 2017-10-09 11:43  耍流氓的兔兔  阅读(145)  评论(0编辑  收藏  举报

 

延迟加载策略:

  延迟加载:

    在真正需要数据的时候,才真正执行数据加载操作

    为了减少数据库的访问效率,减少数据库的访问次数,提高查询性能

    Hibernate通过Proxy机制来实现延迟加载:

      Hibernate从数据库获取某一个对象数据时、获取某一个对象的集合属性值时,或获取某一个对象所关联的另一对象时,由于没有使用该对象的数据(除标识符值外),Hibernate并不从数据库加载真正的数据,而只是为该对象创建一个代理对象来代表这个对象,这个对象上的所有属性都为默认值;只有在真正需要使用该对象的数据时才创建这个真实对象,真正从数据库中加载它的数据

    Hibernate中默认使用延迟加载的情况:

      使用session.load()加载实体时

      当session加载某个实体时,会对实体中的集合属性采用延迟加载

      当session加载某个实体时,会对实体所单端关联的另一个实体采用延迟加载

    属性级别的延迟加载

    session.get默认是非延迟加载

    session.load是属性延迟加载

     Customer c1 = session.get(Customer.class, 15);

     Customer c2 = session.load(Customer.class, 16);

     可以通过在实体对象的映射文件中配置lazy=“false”修改默认的延迟加载策略,即关闭延迟加载

    <class name="com.roxy.hibernate.pojo.Customer" table="t_customer" lazy="false"> 

  类(关联)级别的延迟加载:

    关联级别的延迟加载是默认存在的

    默认情况下hibernate关联级别具有延迟加载的特性

      当session加载某个实体时,会对这个实体所关联的另一个实体对象采用延迟加载

    在一方查询配置:

        Customer c1 = session.get(Customer.class, 1);//此句执行查询customer的sql
   <set name="orders" cascade="save-update, delete" lazy="false">

     在多方查询配置:

 Order o = session.get(Order.class, 3);
<many-to-one name="customer" class="Customer" column="customer_id"  lazy="false"/>