在spring+hibernate的时候,控制台提示“unclosed connection,forgot to call close() on your session?”
或者是[org.hibernate.jdbc.ConnectionManager] - <finalizing with closed connection>
那是因为有可能是你自己手动创建了session,比如:

private static final SessionFactory sessionFactory;

    static {
        try {
            // Create the SessionFactory from hibernate.cfg.xml
            sessionFactory = new Configuration().configure().buildSessionFactory();
        } catch (Throwable ex) {
            // Make sure you log the exception, as it might be swallowed
            System.err.println("Initial SessionFactory creation failed." + ex);
            throw new ExceptionInInitializerError(ex);
        }
    }
然后调用:

Session session = sessionFactory.openSession();
Query query = session.createQuery("from Login");

类似这样的单独使用hibernate时的用法,是需要手工去关闭session的。没有关闭的话就会收到那样的警告。

所以最好是使用spring管理的session,和OpenSessionInViewFilter,比如:
Session session =this.getSession();
然后在web.xml里加入
  <filter>
  <filter-name>OpenSessionInViewFilter</filter-name>
  <filter-class>org.springframework.orm.hibernate3.support.OpenSessionInViewFilter</filter-class>
  </filter>
  <filter-mapping>
<filter-name>OpenSessionInViewFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>

其中在spring里注册的sessionfactory必须是id="sessionFactory",如果是id="SessionFactory"或者其他,会提示sessionFactory没有注册的错误,因为OpenSessionInViewFilter里注册的名必须为sessionFactory。

posted on 2008-01-10 18:41 lzj520 阅读(4822) 评论(5)  编辑  收藏 所属分类: Spring个人学习日记Hibernate

只有注册用户登录后才能发表评论。


网站导航: