【问题标题】:org.hibernate.HibernateException: save is not valid without active transactionorg.hibernate.HibernateException:没有活动事务,保存无效
【发布时间】:2012-08-13 17:19:27
【问题描述】:

我正在创建 JSF 应用程序并在其中使用一些休眠的东西。我想做的就是将实体保存到数据库中,但我不断收到此异常:

org.hibernate.HibernateException: save is not valid without active transaction

起初我遇到了这个异常:

org.hibernate.HibernateException: No CurrentSessionContext configured!

然后我发现我需要将这个添加到我的hibernate配置中:

<property name="hibernate.current_session_context_class">thread</property>

这解决了这个问题,但现在出现了上述问题。 我正在像这样将实体保存到数据库中:

public void create(T entity) {
    getSessionFactory().getCurrentSession().save(entity);
}

我的 hibernate.cfg.xml 文件如下所示:

<hibernate-configuration>
    <session-factory>
        <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
        <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
        <property name="hibernate.connection.url">jdbc:mysql://localhost:3306/online_tests_management</property>
        <property name="hibernate.connection.username">root</property>
        <property name="hibernate.connection.password">root</property>
        <property name="hibernate.show_sql">true</property>
        <property name="hibernate.hbm2ddl.auto">update</property>
        <property name="hibernate.current_session_context_class">thread</property>

        <mapping class="com.groupgti.onlinetests.management.db.Service"/>
    </session-factory>
</hibernate-configuration>

我正在使用:

  • Hibernate-4.1.4.Final
  • JDK 1.6
  • 雄猫 6
  • JSF 2.0
  • PrimeFaces 3.3.1
  • MySql

有人知道问题出在哪里吗?

【问题讨论】:

    标签: java mysql hibernate persistence


    【解决方案1】:

    您必须致电session.beginTransaction()

    public void create(T entity) {
       Session session=getSessionFactory().getCurrentSession();
       Transaction trans=session.beginTransaction();
       session.save(entity);
       trans.commit();
    }
    

    【讨论】:

    • 我正在通过 Spring AOP 使用 spring HibernateTransactionManager 来配置事务。我可以在日志中看到事务正在正常启动,但我的保存仍然失败,因为我没有使用上面的代码。这是为什么呢?
    【解决方案2】:

    尝试将您的方法更改为如下:

    public void create(T entity) {
        getSessionFactory().getCurrentSession().beginTransaction();
        getSessionFactory().getCurrentSession().save(entity);
        getSessionFactory().getCurrentSession().endTransaction();
    }
    

    应该可以解决你的问题。

    【讨论】:

      【解决方案3】:

      这样做:

        public void create(T entity) {
             org.hibernate.Session ss= getSessionFactory().getCurrentSession();
             Transaction tx=ss.beginTransaction();
             ss.save(entity);
             tx.commit();    
        }
      

      自己做异常处理部分。

      【讨论】:

        【解决方案4】:

        我想你会发现这样的东西更加健壮和合适:

        Session session = factory.openSession();
        Transaction tx = null;
        try {
           tx = session.beginTransaction();
        
           // Do some work like:
           //session.load(...);
           //session.persist(...);
           //session.save(...);
        
           tx.commit(); // Flush happens automatically
        }
        catch (RuntimeException e) {
           tx.rollback();
           throw e; // or display error message
        }
        finally {
            session.close();
        }
        

        您不能“关闭”事务,您可以关闭会话,如您所见。阅读this here,它可能对你有用。

        【讨论】:

        • 小心,应该避免使用“openSession”。正确的方法是“getCurrentSession”。
        猜你喜欢
        • 1970-01-01
        • 1970-01-01
        • 2014-08-13
        • 1970-01-01
        • 1970-01-01
        • 2014-09-07
        • 2015-03-05
        • 1970-01-01
        相关资源
        最近更新 更多