我有一个在Tomcat上运行使用Hibernate的JSF应用程序。 我进行了一个小测试,发现了问题 - 创建了一个servlet,它唯一的作用是:
EntityManager em=null;
try {
em = ConnectDb.getEntityManager();
em.createQuery("from Frete").getResultList();
} catch (Exception e) {
e.printStackTrace();
} finally {
try{em.close();}catch(Exception ex){}
}
如果我在pg_admin中执行以下SQL语句,我将得到一条记录,在“query”列中,我可以看到由Hibernate执行的SQL语句,而在“state”列中,则显示“idle in transaction”。
但问题是,并没有开始任何事务,我所做的唯一一件事就是创建一个查询。而EntityManager已经关闭 - 在关闭时没有抛出任何异常。
也许这是在persistence.xml中的配置问题,但我不知道。这是我的persistence.xml:
<?xml version="1.0" encoding="ISO-8859-1"?>
<persistence version="2.0" xmlns="http://java.sun.com/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd">
<persistence-unit name="GestaoPU" transaction-type="RESOURCE_LOCAL">
<provider>org.hibernate.ejb.HibernatePersistence</provider>
<properties>
<property name="hibernate.show_sql" value="true"/>
<property name="hibernate.dialect" value="org.hibernate.dialect.PostgreSQLDialect"/>
<property name="hibernate.connection.autocommit" value="false"/>
<property name="javax.persistence.jdbc.url" value="jdbc:postgresql://localhost/AtualyGestao"/>
<property name="javax.persistence.jdbc.password" value="atg4747"/>
<property name="javax.persistence.jdbc.driver" value="org.postgresql.Driver"/>
<property name="javax.persistence.jdbc.user" value="AtualyGestao"/>
<property name="hibernate.cache.provider_class" value="org.hibernate.cache.NoCacheProvider"/>
<property name="hibernate.format_sql" value="false"/>
<property name="hibernate.connection.encoding" value="ISO-8859-1"/>
</properties>
</persistence-unit>
</persistence>