- 所有已知的子接口:
XAConnection
PooledConnection 对象表示到数据源的物理连接。当应用程序完成连接时,连接可以回收而不是关闭,从而减少需要建立的连接数。
应用程序员不直接使用PooledConnection接口;相反,它由管理连接池的中间层基础设施使用。
当应用程序调用方法 DataSource.getConnection 时,它会返回一个 Connection 对象。如果正在进行连接池,那么 Connection 对象实际上是 PooledConnection 对象的句柄,这是一个物理连接。
连接池管理器,通常是应用程序服务,维护一个包含PooledConnection 个对象的池。如果池中有可用的 PooledConnection 对象,连接池管理器将返回一个 Connection 对象,它是该物理连接的句柄。如果没有 PooledConnection 对象可用,连接池管理器调用 ConnectionPoolDataSource 方法 getPoolConnection 来创建新的物理连接。实现 ConnectionPoolDataSource 的 JDBC 驱动程序创建一个新的 PooledConnection 对象并返回一个句柄。
当应用程序关闭连接时,它会调用 Connection 方法 close 。完成连接池时,连接池管理器会收到通知,因为它已使用 ConnectionPool 方法 addConnectionEventListener 将自己注册为 ConnectionEventListener 对象。连接池管理器停用 PooledConnection 对象的句柄并将 PooledConnection 对象返回到连接池,以便可以再次使用它。因此,当应用程序关闭其连接时,底层物理连接将被回收而不是被关闭。
如果连接池管理器包装或提供从对 PoolConnection.getConnection 的调用返回的逻辑句柄的代理,则当连接池管理器关闭或将 PooledConnection 返回到池以响应应用程序调用 Connection.close 时,池管理器必须执行以下操作之一:
- 在逻辑
Connection句柄上调用endRequest - 在逻辑
Connection句柄上调用close
在连接池管理器调用PooledConnection 方法close 之前,物理连接不会关闭。通常调用此方法以有序关闭服务,或者如果发生致命错误导致连接不可用。
连接池管理器通常也是语句池管理器,维护一个包含 PreparedStatement 个对象的池。当应用程序关闭准备好的语句时,它会调用 PreparedStatement 方法 close 。当完成 Statement 池时,池管理器会收到通知,因为它已使用 ConnectionPool 方法 addStatementEventListener 将自己注册为 StatementEventListener 对象。因此,当应用程序关闭其 PreparedStatement 时,底层准备好的语句将被回收而不是被关闭。
- 自从:
- 1.4
-
方法总结
修饰符和类型方法描述void注册给定的事件监听器,以便在此PooledConnection对象上发生事件时通知它。void向这个PooledConnection对象注册一个StatementEventListener。voidclose()关闭此PooledConnection对象代表的物理连接。创建并返回一个Connection对象,它是此PooledConnection对象表示的物理连接的句柄。void从组件列表中删除给定的事件监听器,当事件发生在此PooledConnection对象上时,这些监听器将被通知。void从组件列表中删除指定的StatementEventListener,当驱动程序检测到PreparedStatement已关闭或无效时,将通知这些组件。
-
方法详情
-
getConnection
创建并返回一个Connection对象,它是此PooledConnection对象表示的物理连接的句柄。当应用程序调用方法DataSource.getConnection并且没有PooledConnection对象可用时,连接池管理器调用此方法。有关详细信息,请参阅interface description。- 返回:
-
一个
Connection对象,它是这个PooledConnection对象的句柄 - 抛出:
SQLException- 如果发生数据库访问错误SQLFeatureNotSupportedException- 如果 JDBC 驱动程序不支持此方法- 自从:
- 1.4
-
close
关闭此PooledConnection对象代表的物理连接。应用程序永远不会直接调用此方法;它由连接池模块或管理器调用。有关详细信息,请参阅
interface description。- 抛出:
SQLException- 如果发生数据库访问错误SQLFeatureNotSupportedException- 如果 JDBC 驱动程序不支持此方法- 自从:
- 1.4
-
addConnectionEventListener
注册给定的事件监听器,以便在此PooledConnection对象上发生事件时通知它。- 参数:
listener- 一个组件,通常是连接池管理器,它实现了ConnectionEventListener接口,希望在连接关闭或出现错误时得到通知- 参见:
-
removeConnectionEventListener
从组件列表中删除给定的事件监听器,当事件发生在此PooledConnection对象上时,这些监听器将被通知。- 参数:
listener- 一个组件,通常是连接池管理器,它实现了ConnectionEventListener接口并作为监听器注册到这个PooledConnection对象- 参见:
-
addStatementEventListener
向这个PooledConnection对象注册一个StatementEventListener。希望在连接创建的PreparedStatement关闭或检测到无效时收到通知的组件可以使用此方法向此PooledConnection对象注册一个StatementEventListener。- 参数:
listener- 实现StatementEventListener接口的组件,要注册到这个PooledConnection对象- 自从:
- 1.6
-
removeStatementEventListener
从组件列表中删除指定的StatementEventListener,当驱动程序检测到PreparedStatement已关闭或无效时,将通知这些组件。- 参数:
listener- 实现先前注册到此PooledConnection对象的StatementEventListener接口的组件- 自从:
- 1.6
-