org.hibernate.LazyInitializationException: could not initialize proxy - no Session

这个回答转自:http://blog.sina.com.cn/s/blog_85987afc0100ukl0.html

因为我们在hibernate里面load一个对象出来时,用到的是代理对象,也就是说当我们在执行load方法时并没有发sql语句,而是返回一个 proxy对象。只有当们具体用到哪个get**方法时才会发sql语句,才会去数据库查。但是当我们把打开session,关闭session交给了 srping去做时,当们load完之后我们的session就会被srping关闭,如果我们在jsp页面或者其它的地方再去用get方法取值时就会报 这个错误。
解决方法一:但如果我们在hibernate用get方法就可以解决取单个对象的问题,因为get方法直接发sql语句,把我们想的数据从数据库中get出来然后放在内存中。
如果我们取单个对象可以用get方法没有问题;但是如果我们取的的对象还有关联对象时用get就有问题,因为它不会把关联的对象取出来,但如果页面上用到关联的对象时也会报no session的问题
解决方法二:用到srping的filter(要加在strutsfilter有前面,因为它也有先后顺序,有先进先出的原则)
在我们的web.xml里面加上
<filter>
<filter-name>openSessionInView</filter-name>
<filter-class>org.springframework.orm.hibernate3.support.OpenSessionInViewFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>openSessionInView</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
这样做就是让opensession closesession全交给视图部分,最后视图部分用完了session再去关session就不会有上面的错误了

我是使用hibernate的query的uniqueResult()方法时候报的这个错。
我估计是uniqueResult底层使用了延迟加载。我在查询方法的dao类中finally写了session.close(),然后在test类中使用对象的对应属性进行查询的时候发现没有session了所以报了这个错。
public Person queryUniqueResult(int id){
        Session session=HibernateSessionFactory.getSession();
        Transaction tx=session.beginTransaction();
        Person p = null;
        try{
        Query query=session.createQuery("from Person where id=:id");
        query.setInteger("id", id);
        p=(Person) query.uniqueResult();
        tx.commit();
        }catch(Exception e){
            e.printStackTrace();
            tx.rollback();
        }/*finally{
            session.close();
        }*/
        return p;
    }

 

posted @ 2016-04-28 14:13  guodaxia  阅读(243)  评论(0)    收藏  举报