|
摘要: 嵌套 | 字段 | 构造方法 | 方法 | 详细信息: 字段 | 构造方法 | 方法 |
java.sql
接口 Wrapper
- 所有已知子接口:
- CachedRowSet, CallableStatement, Connection, DatabaseMetaData, DataSource, FilteredRowSet, JdbcRowSet, JoinRowSet, ParameterMetaData, PreparedStatement, ResultSet, ResultSetMetaData, RowSet, RowSetMetaData, Statement, SyncResolver, WebRowSet
- 所有已知实现类:
- RowSetMetaDataImpl
public interface Wrapper
在相关实例实际上是代理类时提供获取委托实例能力的 JDBC 类的接口。
许多 JDBC 驱动程序实现使用包装器模式提供超越传统 JDBC API 的扩展,传统 JDBC API 是特定于数据源的。开发人员可能希望访问那些被包装(代理)为代表实际资源代理类实例的资源。此接口描述访问那些由代理代表的包装资源的标准机制,以允许对资源代理的直接访问。
- 从以下版本开始:
- 1.6
方法摘要 |
---|
boolean | isWrapperFor(Class<?> iface) 如果调用此方法的对象实现接口参数,或者是实现接口参数的对象的直接或间接包装器,则返回 true。 |
| unwrap(Class<T> iface) 返回一个对象,该对象实现给定接口,以允许访问非标准方法或代理未公开的标准方法。 |
unwrap
<T> T unwrap(Class<T> iface)
throws SQLException
- 返回一个对象,该对象实现给定接口,以允许访问非标准方法或代理未公开的标准方法。 如果接收者实现了该接口,那么结果是接收者或接收者代理。如果接收者是包装器且包装对象实现了该接口,那么结果是包装对象或包装对象的代理。否则,返回以递归方式对包装对象调用
unwrap
的结果或该结果的代理。如果接收者不是包装器且未实现该接口,则抛出 SQLException
。 - 参数:
iface
- 定义结果必须实现的接口的 Class。 - 返回:
- 实现接口的对象。可以是实际实现对象的代理。
- 抛出:
SQLException
- 如果未找到实现接口的对象。 - 从以下版本开始:
- 1.6
isWrapperFor
boolean isWrapperFor(Class<?> iface)
throws SQLException
- 如果调用此方法的对象实现接口参数,或者是实现接口参数的对象的直接或间接包装器,则返回 true。否则返回 false。如果调用此方法的对象实现了接口,则返回 true;如果它是包装器,则返回以递归方式对包装对象调用
isWrapperFor
的结果。如果调用此方法的对象未实现该接口且不是包装器,则返回 false。此方法相比 unwrap
而言,应作为低成本操作实现,以便调用者可以使用此方法避免调用可能失败的昂贵的 unwrap
。如果此方法返回 true,那么使用相同的参数调用 unwrap
应该会成功。 - 参数:
iface
- 定义接口的 Class。 - 返回:
- 如果调用此方法的对象实现了接口,或者直接或间接包装实现了接口的对象,则返回 true。
- 抛出:
SQLException
- 如果在确定调用此方法的对象是否是使用给定接口的对象的包装器时发生错误。 - 从以下版本开始:
- 1.6
|
摘要: 嵌套 | 字段 | 构造方法 | 方法 | 详细信息: 字段 | 构造方法 | 方法 |