Java 在另一个会话中休眠初始化对象

Java 在另一个会话中休眠初始化对象,java,hibernate,session,Java,Hibernate,Session,我有一个非常简单的实体对象User,它与用户角色有关。麻烦的是,当我从数据库中获取用户对象并将其传递给另一个方法时,该方法希望访问该用户对象中的用户角色,我得到了一个著名的无法初始化代理Hibernate异常 例:方法1: - open session, open transaction - fetch user - close transaction, close session 现在将该用户对象传递给方法2 - open session, open transaction - do Hi

我有一个非常简单的实体对象User,它与用户角色有关。麻烦的是,当我从数据库中获取用户对象并将其传递给另一个方法时,该方法希望访问该用户对象中的用户角色,我得到了一个著名的无法初始化代理Hibernate异常

例:方法1:

- open session, open transaction
- fetch user 
- close transaction, close session
现在将该用户对象传递给方法2

- open session, open transaction
- do Hibernate.initialize(user.getUserRole()) --> here it breaks
- close transaction, close session
我猜这是某种Hibernate特性,您无法在新会话中初始化对象,但我不知道为什么。有什么解决办法吗

另外,我已经读过关于
true
的内容,但这和正常的做法一样,没有必要打开此选项

编辑:代码示例:

用户类的getter和setter

@ManyToOne(fetch = FetchType.LAZY, targetEntity = UserRoles.class)
@JoinColumn(name = "USER_ROLE_ID", nullable = false)
public UserRoles getUserRoles() {
    return this.userRoles;
}

public void setUserRoles(UserRoles userRoles) {
    this.userRoles = userRoles;
}
用户角色字段

 private Integer id;
 private String description;
 private Character active;
 private Set userses = new HashSet(0);
方法1

public static void method1() {
    Users user = null;
    Session session = HibernateUtil.getSessionFactory().openSession();
    Transaction tx = null;
    try {
        tx = session.beginTransaction();
        String hqlQuery = "FROM Users WHERE userName = :userName";
        Query query = session.createQuery(hqlQuery);
        query.setParameter("userName", userName);
        List<Users> list = query.list();    
        for (Users u : list) {
            user = u;
            break;
        }
        tx.commit();
    } catch (HibernateException e) {
        if (tx != null)
            tx.rollback();
        Logging.handleExceptionLogging(e);
    } finally {
        session.close();
    }

    method2(user);
}

所以基本上在谷歌搜索和阅读了大量关于会话的信息后,我的假设是正确的。实体对象几乎“绑定”到原始会话,在原始会话中获取实体对象,这样的查询不能以这种方式执行。一种解决方案是将实体绑定到调用session.update(实体)的新会话,并且这个新会话不知道实体。基本上,发出新查询是为了再次填充实体字段。所以,如果没有必要,请避免这种情况,并尝试在原始会话中获取所有需要的数据


更多阅读:

可能会发布您的实体以及如何调用获取?我提供了代码示例(其中大部分),tnx
public static method2(Users user) {

if (user != null) {

        if (Hibernate.isInitialized(user.getUserRoles())) {
            if (user.getUserRoles().getDescription() != null && user.getUserRoles().getDescription().toLowerCase().equals("admin"))
                returnValue = true;
        } else {
            Session session = HibernateUtil.getSessionFactory().openSession();
            Transaction tx = null;
            try {
                tx = session.beginTransaction();
                Hibernate.initialize(user.getUserRoles()); // this line causes Exception
                if (user.getUserRoles().getDescription().toLowerCase().equals("admin"))
                    returnValue = true;
                tx.commit();
            } catch (HibernateException e) {
                if (tx != null)
                    tx.rollback();
                Logging.handleExceptionLogging(e);
            } finally {
                session.close();
            }
        }
    }
}