gpt4 book ai didi

Hibernate + PostgreSQL - 与状态 "Idle in transaction"的连接

转载 作者:行者123 更新时间:2023-11-29 11:25:14 24 4
gpt4 key购买 nike

我有一个使用 Hibernate 在 Tomcat 上运行的 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>

最佳答案

the only thing i did was create a query

看来你也执行了:

em.createQuery("from Frete").getResultList();

当你执行这一行时:hibernate 执行查询并为此由 postgresql 驱动程序创建一个事务。

由于自动提交设置为 false :

  <property name="hibernate.connection.autocommit" value="false"/>

然后事务未提交,这就是您收到此消息的原因。

顺便说一句:而不是

try{em.close();}catch(Exception ex){}

这样写:

try{em.close();}catch(Exception ex){ex.printStacktrace();}

关于Hibernate + PostgreSQL - 与状态 "Idle in transaction"的连接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20760867/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com