zoukankan      html  css  js  c++  java
  • hibernate manytoone中的lazy EAGER

    Hibernate中的字段映射中的Fetch有两种方式:EAGER和LAZY

    Eager:全部抓取

    Lazy:延迟抓取

    如果在字段中声明为Eager,那么在取得当前Bean时,同时会抓取Bean中的关联Bean值。即数据库查询多次。反之Lazy则在之后抓取提交查询。

    比如,有如下声明为Eager的User Bean:

        @OneToMany(mappedBy="user", cascade=CascadeType.ALL, fetch=FetchType.EAGER)
        private Set<UserCard> cards;

    此时使用Join查询时,将会同时把User bean下的cards均一同查询出来:

    复制代码
                // ----------------------------------------------------
                // Left join
                // ----------------------------------------------------
                String hql = "SELECT U FROM User U LEFT JOIN U.cards C WHERE U.userName=:userName AND C.cardID=:cardID";
                Query query = session.createQuery(hql);
                query.setLong("cardID", 1);
                query.setString("userName", "Robin");
                List<User> users = query.list();
                for (User user : users) {
                    System.out.println("User ID:" + user.getUserID()
                            + "	User name:" + user.getUserName());
                }
    复制代码

    输出的SQL和查询结果:

    如果把Eager修改为Lazy:

        @OneToMany(mappedBy="user", cascade=CascadeType.ALL, fetch=FetchType.LAZY)
        private Set<UserCard> cards;

    查询:

    复制代码
                // ----------------------------------------------------
                // Left join
                // ----------------------------------------------------
                String hql = "SELECT U FROM User U LEFT JOIN U.cards C WHERE U.userName=:userName AND C.cardID=:cardID";
                Query query = session.createQuery(hql);
                query.setLong("cardID", 1);
                query.setString("userName", "Robin");
                List<User> users = query.list();
                for (User user : users) {
                    System.out.println("User ID:" + user.getUserID()
                            + "	User name:" + user.getUserName());
                }
    复制代码

    输出的SQL和查询结果:


    当然,大多数情况下,bean的设计都应该为Lazy。

    因为如果真要同步查询得到关联对象bean的值,可以在hql中加入FETCH关键字即可完成。

    Fetch参考例子:http://www.cnblogs.com/HD/p/3957926.html

    使用FETCH,如上查询hql可以写为:

    String hql = "SELECT U FROM User U LEFT FETCH JOIN U.cards C WHERE U.userName=:userName AND C.cardID=:cardID";

     上面是转载其他前辈的资料,在本人的项目中,曾经发现实体类a里已经有了实体类B的id,但是总是获取不到该实体,后来发现是映射时设置了lazy,导致延迟加载,是在session中获取,但是此时session里是没有该实体的,所以改成了mager来从内存中获取。

  • 相关阅读:
    《海量数据库解决方式》读后感
    HDU-3533-Escape(BFS)
    (017)将一棵二叉查找树重构成链表(keep it up)
    hadoop招聘需求每天都在添加,短短半个月时间,需求量差点儿翻了一番,这是大数据要爆发的节奏么?
    关于Oracle安装完毕后,登录时遇到的错误的解决的方法
    C/C++产生随机数
    android手机SD卡中的android_secure目录
    【Unity Shaders】Lighting Models —— 衣服着色器
    ASM相关视图
    win2003的IIS無法使用,又一次安裝提示找不到iisadmin.mfl文件
  • 原文地址:https://www.cnblogs.com/mrdoor/p/4691546.html
Copyright © 2011-2022 走看看