在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 閱讀(4838) 評論(5)  編輯  收藏 所屬分類: Spring個人學習日記Hibernate
          主站蜘蛛池模板: 阿克| 顺平县| 道真| 丰都县| 阿克陶县| 长治县| 同心县| 绵竹市| 樟树市| 行唐县| 林西县| 滨州市| 叶城县| 诏安县| 昭平县| 绥阳县| 平顺县| 盈江县| 木里| 合水县| 榕江县| 资兴市| 抚州市| 灯塔市| 乌海市| 建水县| 新化县| 钦州市| 平原县| 屏东县| 徐闻县| 商城县| 曲沃县| 冷水江市| 库尔勒市| 客服| 宣城市| 德保县| 甘洛县| 太保市| 托克逊县|