Package org.postgresql.ds
Class PGPooledConnection
- java.lang.Object
-
- org.postgresql.ds.PGPooledConnection
-
- All Implemented Interfaces:
PooledConnection
- Direct Known Subclasses:
PGXAConnection
public class PGPooledConnection extends Object implements PooledConnection
PostgreSQL implementation of the PooledConnection interface. This shouldn't be used directly, as the pooling client should just interact with the ConnectionPool instead.- Author:
- Aaron Mulder (ammulder@chariotsolutions.com), Csaba Nagy (ncsaba@yahoo.com)
- See Also:
PGConnectionPoolDataSource
-
-
Constructor Summary
Constructors Constructor Description PGPooledConnection(Connection con, boolean autoCommit)PGPooledConnection(Connection con, boolean autoCommit, boolean isXA)Creates a new PooledConnection representing the specified physical connection.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaddConnectionEventListener(ConnectionEventListener connectionEventListener)Adds a listener for close or fatal error events on the connection handed out to a client.voidaddStatementEventListener(StatementEventListener listener)voidclose()Closes the physical database connection represented by this PooledConnection.protected ConnectionEventcreateConnectionEvent(SQLException e)ConnectiongetConnection()Gets a handle for a client to use.voidremoveConnectionEventListener(ConnectionEventListener connectionEventListener)Removes a listener for close or fatal error events on the connection handed out to a client.voidremoveStatementEventListener(StatementEventListener listener)
-
-
-
Constructor Detail
-
PGPooledConnection
public PGPooledConnection(Connection con, boolean autoCommit, boolean isXA)
Creates a new PooledConnection representing the specified physical connection.- Parameters:
con- connectionautoCommit- whether to autocommitisXA- whether connection is a XA connection
-
PGPooledConnection
public PGPooledConnection(Connection con, boolean autoCommit)
-
-
Method Detail
-
addConnectionEventListener
public void addConnectionEventListener(ConnectionEventListener connectionEventListener)
Adds a listener for close or fatal error events on the connection handed out to a client.- Specified by:
addConnectionEventListenerin interfacePooledConnection
-
removeConnectionEventListener
public void removeConnectionEventListener(ConnectionEventListener connectionEventListener)
Removes a listener for close or fatal error events on the connection handed out to a client.- Specified by:
removeConnectionEventListenerin interfacePooledConnection
-
close
public void close() throws SQLExceptionCloses the physical database connection represented by this PooledConnection. If any client has a connection based on this PooledConnection, it is forcibly closed as well.- Specified by:
closein interfacePooledConnection- Throws:
SQLException
-
getConnection
public Connection getConnection() throws SQLException
Gets a handle for a client to use. This is a wrapper around the physical connection, so the client can call close and it will just return the connection to the pool without really closing the pgysical connection.According to the JDBC 2.0 Optional Package spec (6.2.3), only one client may have an active handle to the connection at a time, so if there is a previous handle active when this is called, the previous one is forcibly closed and its work rolled back.
- Specified by:
getConnectionin interfacePooledConnection- Throws:
SQLException
-
createConnectionEvent
protected ConnectionEvent createConnectionEvent(SQLException e)
-
removeStatementEventListener
public void removeStatementEventListener(StatementEventListener listener)
- Specified by:
removeStatementEventListenerin interfacePooledConnection
-
addStatementEventListener
public void addStatementEventListener(StatementEventListener listener)
- Specified by:
addStatementEventListenerin interfacePooledConnection
-
-