在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