All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.springframework.jdbc.support.nativejdbc.Jdbc4NativeJdbcExtractor Maven / Gradle / Ivy

There is a newer version: 6.1.6
Show newest version
/*
 * Copyright 2002-2012 the original author or authors.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package org.springframework.jdbc.support.nativejdbc;

import java.sql.CallableStatement;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

/**
 * {@link NativeJdbcExtractor} implementation that delegates to JDBC 4.0's
 * {@code unwrap} method, as defined by {@link java.sql.Wrapper}.
 * You will typically need to specify a vendor {@link #setConnectionType Connection type}
 * / {@link #setStatementType Statement type} / {@link #setResultSetType ResultSet type}
 * to extract, since JDBC 4.0 only actually unwraps to a given target type.
 *
 * 

Note: Only use this when actually running against a JDBC 4.0 driver, with a * connection pool that supports the JDBC 4.0 API (i.e. at least accepts JDBC 4.0 * API calls and passes them through to the underlying driver)! Other than that, * there is no need for connection pool specific setup. As of JDBC 4.0, * NativeJdbcExtractors will typically be implemented for specific drivers * instead of for specific pools (e.g. {@link OracleJdbc4NativeJdbcExtractor}). * * @author Juergen Hoeller * @since 2.5 * @see java.sql.Wrapper#unwrap * @see SimpleNativeJdbcExtractor * @see org.springframework.jdbc.core.JdbcTemplate#setNativeJdbcExtractor * @see org.springframework.jdbc.support.lob.OracleLobHandler#setNativeJdbcExtractor */ public class Jdbc4NativeJdbcExtractor extends NativeJdbcExtractorAdapter { private Class connectionType = Connection.class; private Class statementType = Statement.class; private Class preparedStatementType = PreparedStatement.class; private Class callableStatementType = CallableStatement.class; private Class resultSetType = ResultSet.class; /** * Set the vendor's Connection type, e.g. {@code oracle.jdbc.OracleConnection}. */ public void setConnectionType(Class connectionType) { this.connectionType = connectionType; } /** * Set the vendor's Statement type, e.g. {@code oracle.jdbc.OracleStatement}. */ public void setStatementType(Class statementType) { this.statementType = statementType; } /** * Set the vendor's PreparedStatement type, e.g. {@code oracle.jdbc.OraclePreparedStatement}. */ public void setPreparedStatementType(Class preparedStatementType) { this.preparedStatementType = preparedStatementType; } /** * Set the vendor's CallableStatement type, e.g. {@code oracle.jdbc.OracleCallableStatement}. */ public void setCallableStatementType(Class callableStatementType) { this.callableStatementType = callableStatementType; } /** * Set the vendor's ResultSet type, e.g. {@code oracle.jdbc.OracleResultSet}. */ public void setResultSetType(Class resultSetType) { this.resultSetType = resultSetType; } @Override protected Connection doGetNativeConnection(Connection con) throws SQLException { return con.unwrap(this.connectionType); } @Override public Statement getNativeStatement(Statement stmt) throws SQLException { return stmt.unwrap(this.statementType); } @Override public PreparedStatement getNativePreparedStatement(PreparedStatement ps) throws SQLException { return ps.unwrap(this.preparedStatementType); } @Override public CallableStatement getNativeCallableStatement(CallableStatement cs) throws SQLException { return cs.unwrap(this.callableStatementType); } @Override public ResultSet getNativeResultSet(ResultSet rs) throws SQLException { return rs.unwrap(this.resultSetType); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy