Hibernate,不支持嵌套事务

时间:2017-01-18 17:05:33

标签: java hibernate

我在运行我的Web应用程序时遇到了麻烦,该应用程序尝试从表滑雪板获取所有信息并将其放入列表中,然后我将在xHtml中打印出来。但我在下面得到了这个例外。

  

org.hibernate.TransactionException:不支持嵌套事务

问题是我不知道为什么会发生这种异常,所以会有一些解释。此外,如果您在代码中发现任何问题都会很棒。

这是我得到的例外。

的HibernateUtil

public class HibernateUtil {

    private static final SessionFactory sessionFactory;

    static {



        try {
            // Create the SessionFactory from standard (hibernate.cfg.xml) 
            // config file.
            sessionFactory = new AnnotationConfiguration().configure().buildSessionFactory();
        } catch (Throwable ex) {
            // Log the exception. 
            System.err.println("Initial SessionFactory creation failed." + ex);
            throw new ExceptionInInitializerError(ex);
        }
    }

    public static SessionFactory getSessionFactory() {
        return sessionFactory;
    }
}

SnowHelper,HelperClass

public class SnowHelper {

    Session session = null;

    public SnowHelper() {
        this.session = HibernateUtil.getSessionFactory().getCurrentSession();
    }

    public List getSnowboards() {
        List<Snowboard> snowboardList = null;

        try {
            Transaction tx = session.beginTransaction();
            Query q = session.createQuery("from Snowboard");
            snowboardList = (List<Snowboard>) q.list();

        } catch (Exception e) {
            e.printStackTrace();
        }

        return snowboardList;
    }
}

HibernateCfg

<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://cpsrv01.misshosting.com:3306/etvffqgz_snowshop</property>
    <property name="hibernate.connection.username">etvffqgz_user</property>
    <property name="hibernate.connection.password">759486456</property>
    <property name="hibernate.show_sql">true</property>
    <property name="hibernate.current_session_context_class">thread</property>
    <property name="hibernate.query.factory_class">org.hibernate.hql.internal.classic.ClassicQueryTranslatorFactory</property>
    <mapping resource="Hibernate/Account.hbm.xml"/>
    <mapping resource="Hibernate/Snowboard.hbm.xml"/>
  </session-factory>
</hibernate-configuration>

SnowboardBean,ManagedBean类

@Named(value = "snowboardBean")
@Dependent
public class SnowboardBean {

    private List<Snowboard> snowList;
    private SnowHelper snow;
    /**
     * Creates a new instance of SnowboardBean
     */
    public SnowboardBean() {
        snowList = new ArrayList<>();
        snow = new SnowHelper();

        snowList = snow.getSnowboards();
    }

    /**
     * @return the snowList
     */
    public List<Snowboard> getSnowList() {
        return snowList;
    }

}

1 个答案:

答案 0 :(得分:1)

在此处...提交您的交易

Transaction tx = session.beginTransaction();
Query q = session.createQuery("from Snowboard");
snowboardList = (List<Snowboard>) q.list();
tx.commit();

否则,每次调用此方法时,只需打开一个新事务而不关闭它。最终其中一个被打开而另一个尚未提交。

如果您使用'容器管理事务'(由Spring的EJB提供),您不必担心显式提交您的事务。在这里,您使用的是“扩展交易管理”,您必须自己处理。