Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/postgresql/9.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java Postgresql和GlassFish-启用自动提交时无法提交_Java_Postgresql_Jdbc_Glassfish_Mybatis - Fatal编程技术网

Java Postgresql和GlassFish-启用自动提交时无法提交

Java Postgresql和GlassFish-启用自动提交时无法提交,java,postgresql,jdbc,glassfish,mybatis,Java,Postgresql,Jdbc,Glassfish,Mybatis,我有postgresql9.4和glassfish4.1。此外,我在EJB中使用MyBatis。现在我尝试从表中选择,我得到的结果如下: javax.resource.spi.LocalTransactionException: Cannot commit when autoCommit is enabled. at com.sun.gjc.spi.LocalTransactionImpl.commit(LocalTransactionImpl.java:112) at com.

我有
postgresql9.4
glassfish4.1
。此外,我在EJB中使用MyBatis。现在我尝试从表中选择,我得到的结果如下:

javax.resource.spi.LocalTransactionException: Cannot commit when autoCommit is enabled.
    at com.sun.gjc.spi.LocalTransactionImpl.commit(LocalTransactionImpl.java:112)
    at com.sun.enterprise.resource.ConnectorXAResource.commit(ConnectorXAResource.java:124)
    at com.sun.enterprise.transaction.JavaEETransactionImpl.commit(JavaEETransactionImpl.java:518)
    at com.sun.enterprise.transaction.JavaEETransactionManagerSimplified.commit(JavaEETransactionManagerSimplified.java:854)
    at com.sun.ejb.containers.EJBContainerTransactionManager.completeNewTx(EJBContainerTransactionManager.java:719)
    at com.sun.ejb.containers.EJBContainerTransactionManager.postInvokeTx(EJBContainerTransactionManager.java:503)
    at com.sun.ejb.containers.BaseContainer.postInvokeTx(BaseContainer.java:4566)
    at com.sun.ejb.containers.BaseContainer.postInvoke(BaseContainer.java:2074)
    at com.sun.ejb.containers.BaseContainer.postInvoke(BaseContainer.java:2044)
    at com.sun.ejb.containers.EJBObjectInvocationHandler.invoke(EJBObjectInvocationHandler.java:212)
    at com.sun.ejb.containers.EJBObjectInvocationHandlerDelegate.invoke(EJBObjectInvocationHandlerDelegate.java:79)
    at com.sun.proxy.$Proxy312.getLsist(Unknown Source)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:483)
    at com.sun.corba.ee.impl.presentation.rmi.ReflectiveTie.dispatchToMethod(ReflectiveTie.java:143)
    at com.sun.corba.ee.impl.presentation.rmi.ReflectiveTie._invoke(ReflectiveTie.java:173)
    at com.sun.corba.ee.impl.protocol.ServerRequestDispatcherImpl.dispatchToServant(ServerRequestDispatcherImpl.java:528)
    at com.sun.corba.ee.impl.protocol.ServerRequestDispatcherImpl.dispatch(ServerRequestDispatcherImpl.java:199)
    at com.sun.corba.ee.impl.protocol.MessageMediatorImpl.handleRequestRequest(MessageMediatorImpl.java:1549)
    at com.sun.corba.ee.impl.protocol.MessageMediatorImpl.handleRequest(MessageMediatorImpl.java:1425)
    at com.sun.corba.ee.impl.protocol.MessageMediatorImpl.handleInput(MessageMediatorImpl.java:930)
    at com.sun.corba.ee.impl.protocol.giopmsgheaders.RequestMessage_1_2.callback(RequestMessage_1_2.java:213)
    at com.sun.corba.ee.impl.protocol.MessageMediatorImpl.handleRequest(MessageMediatorImpl.java:694)
    at com.sun.corba.ee.impl.protocol.MessageMediatorImpl.dispatch(MessageMediatorImpl.java:496)
    at com.sun.corba.ee.impl.transport.ConnectionImpl$1.dispatch(ConnectionImpl.java:195)
    at com.sun.corba.ee.impl.transport.ConnectionImpl.read(ConnectionImpl.java:328)
    at com.sun.corba.ee.impl.transport.ReaderThreadImpl.doWork(ReaderThreadImpl.java:112)
    at com.sun.corba.ee.impl.threadpool.ThreadPoolImpl$WorkerThread.performWork(ThreadPoolImpl.java:497)
    at com.sun.corba.ee.impl.threadpool.ThreadPoolImpl$WorkerThread.run(ThreadPoolImpl.java:540)
Caused by: org.postgresql.util.PSQLException: Cannot commit when autoCommit is enabled.
    at org.postgresql.jdbc2.AbstractJdbc2Connection.commit(AbstractJdbc2Connection.java:811)
    at com.sun.gjc.spi.LocalTransactionImpl.commit(LocalTransactionImpl.java:106)
    ... 30 more
我甚至尝试了以下代码:

SqlSession session = ConnectionFactory.getSession().openSession(false);//AUTOCOMMIT
        List list=null;
        try{
            session.getConnection().setAutoCommit(false);
            TempMapper mapper = (TempMapper)session.getMapper(TempMapper.class);
            list=mapper.readAll();
        }  
        catch (SQLException ex) {
            Logger.getLogger(TempBean.class.getName()).log(Level.SEVERE, null, ex);
        }        finally {
            session.close();
        }

然而,结果是一样的。当我使用gf+mysql+mybatis时,我更改了relaxautocommit,但对于postgresql驱动程序,没有这样的属性。如何解决此问题?

解决方案:在glassfish web控制台中打开postgresql池,并在事务部分设置启用非事务性连接。

在glassfish管理控制台中。