org.mariadb.jdbc.AbstractCallableProcedureStatement Maven / Gradle / Ivy
/*
MariaDB Client for Java
Copyright (c) 2012-2014 Monty Program Ab.
Copyright (c) 2015-2016 MariaDb Ab.
This library is free software; you can redistribute it and/or modify it under
the terms of the GNU Lesser General Public License as published by the Free
Software Foundation; either version 2.1 of the License, or (at your option)
any later version.
This library is distributed in the hope that it will be useful, but
WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License
for more details.
You should have received a copy of the GNU Lesser General Public License along
with this library; if not, write to Monty Program Ab [email protected].
This particular MariaDB Client for Java file is work
derived from a Drizzle-JDBC. Drizzle-JDBC file which is covered by subject to
the following copyright and notice provisions:
Copyright (c) 2009-2011, Marcus Eriksson, Trond Norbye, Stephane Giron
Redistribution and use in source and binary forms, with or without modification,
are permitted provided that the following conditions are met:
Redistributions of source code must retain the above copyright notice, this list
of conditions and the following disclaimer.
Redistributions in binary form must reproduce the above copyright notice, this
list of conditions and the following disclaimer in the documentation and/or
other materials provided with the distribution.
Neither the name of the driver nor the names of its contributors may not be
used to endorse or promote products derived from this software without specific
prior written permission.
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY
OF SUCH DAMAGE.
*/
package org.mariadb.jdbc;
import org.mariadb.jdbc.internal.queryresults.resultset.MariaSelectResultSet;
import org.mariadb.jdbc.internal.util.ExceptionMapper;
import java.io.InputStream;
import java.io.Reader;
import java.math.BigDecimal;
import java.net.URL;
import java.sql.*;
import java.util.Calendar;
import java.util.List;
import java.util.Map;
public abstract class AbstractCallableProcedureStatement extends MariaDbServerPreparedStatement implements CallableStatement, Cloneable {
/**
* Information about parameters, merely from registerOutputParameter() and setXXX() calls.
*/
protected List params;
protected int[] outputParameterMapper = null;
protected CallableParameterMetaData parameterMetadata;
protected boolean hasInOutParameters;
protected boolean hasOutParameters;
/**
* Constructor for getter/setter of callableStatement.
* @param connection current connection
* @param sql query
* @param resultSetScrollType one of the following ResultSet
constants: ResultSet.TYPE_FORWARD_ONLY
,
* ResultSet.TYPE_SCROLL_INSENSITIVE
, or ResultSet.TYPE_SCROLL_SENSITIVE
* @throws SQLException is prepareStatement connection throw any error
*/
public AbstractCallableProcedureStatement(MariaDbConnection connection, String sql, int resultSetScrollType)
throws SQLException {
super(connection, sql, resultSetScrollType, true);
}
/**
* Clone data.
*
* @return Cloned .
* @throws CloneNotSupportedException if any error occur.
*/
public AbstractCallableProcedureStatement clone() throws CloneNotSupportedException {
AbstractCallableProcedureStatement clone = (AbstractCallableProcedureStatement) super.clone();
clone.params = params;
clone.parameterMetadata = parameterMetadata;
return clone;
}
/**
* Set in/out parameters value.
*/
public void setParametersVariables() {
hasInOutParameters = false;
hasOutParameters = false;
for (CallParameter param : params) {
if (param != null) {
if (param.isOutput) {
hasOutParameters = true;
if (param.isInput) {
hasInOutParameters = true;
break;
}
}
}
}
}
protected abstract MariaSelectResultSet getResult() throws SQLException;
public ParameterMetaData getParameterMetaData() throws SQLException {
parameterMetadata.readMetadataFromDbIfRequired();
return parameterMetadata;
}
/**
* Convert parameter name to parameter index in the query.
*
* @param parameterName name
* @return index
* @throws SQLException exception
*/
private int nameToIndex(String parameterName) throws SQLException {
parameterMetadata.readMetadataFromDbIfRequired();
for (int i = 1; i <= parameterMetadata.getParameterCount(); i++) {
String name = parameterMetadata.getName(i);
if (name != null && name.equalsIgnoreCase(parameterName)) {
return i;
}
}
throw new SQLException("there is no parameter with the name " + parameterName);
}
/**
* Convert parameter name to output parameter index in the query.
*
* @param parameterName name
* @return index
* @throws SQLException exception
*/
private int nameToOutputIndex(String parameterName) throws SQLException {
parameterMetadata.readMetadataFromDbIfRequired();
for (int i = 0; i < parameterMetadata.getParameterCount(); i++) {
String name = parameterMetadata.getName(i + 1);
if (name != null && name.equalsIgnoreCase(parameterName)) {
if (outputParameterMapper[i] == -1) {
//this is not an outputParameter
throw new SQLException("Parameter '" + parameterName
+ "' is not declared as output parameter with method registerOutParameter");
}
return outputParameterMapper[i];
}
}
throw new SQLException("there is no parameter with the name " + parameterName);
}
/**
* Convert parameter index to corresponding outputIndex.
*
* @param parameterIndex index
* @return index
* @throws SQLException exception
*/
private int indexToOutputIndex(int parameterIndex) throws SQLException {
try {
if (outputParameterMapper[parameterIndex - 1] == -1) {
//this is not an outputParameter
throw new SQLException("Parameter in index '" + parameterIndex
+ "' is not declared as output parameter with method registerOutParameter");
}
return outputParameterMapper[parameterIndex - 1];
} catch (ArrayIndexOutOfBoundsException arrayIndexOutOfBoundsException) {
if (parameterIndex < 1) {
throw new SQLException("Index " + parameterIndex + " must at minimum be 1");
}
throw new SQLException("Index value '" + parameterIndex
+ "' is incorrect. Maximum value is " + params.size());
}
}
@Override
public boolean wasNull() throws SQLException {
return getResult().wasNull();
}
@Override
public String getString(int parameterIndex) throws SQLException {
return getResult().getString(indexToOutputIndex(parameterIndex));
}
@Override
public String getString(String parameterName) throws SQLException {
return getResult().getString(nameToOutputIndex(parameterName));
}
@Override
public boolean getBoolean(int parameterIndex) throws SQLException {
return getResult().getBoolean(indexToOutputIndex(parameterIndex));
}
@Override
public boolean getBoolean(String parameterName) throws SQLException {
return getResult().getBoolean(nameToOutputIndex(parameterName));
}
@Override
public byte getByte(int parameterIndex) throws SQLException {
return getResult().getByte(indexToOutputIndex(parameterIndex));
}
@Override
public byte getByte(String parameterName) throws SQLException {
return getResult().getByte(nameToOutputIndex(parameterName));
}
@Override
public short getShort(int parameterIndex) throws SQLException {
return getResult().getShort(indexToOutputIndex(parameterIndex));
}
@Override
public short getShort(String parameterName) throws SQLException {
return getResult().getShort(nameToOutputIndex(parameterName));
}
@Override
public int getInt(String parameterName) throws SQLException {
return getResult().getInt(nameToOutputIndex(parameterName));
}
@Override
public int getInt(int parameterIndex) throws SQLException {
return getResult().getInt(indexToOutputIndex(parameterIndex));
}
@Override
public long getLong(String parameterName) throws SQLException {
return getResult().getLong(nameToOutputIndex(parameterName));
}
@Override
public long getLong(int parameterIndex) throws SQLException {
return getResult().getLong(indexToOutputIndex(parameterIndex));
}
@Override
public float getFloat(String parameterName) throws SQLException {
return getResult().getFloat(nameToOutputIndex(parameterName));
}
@Override
public float getFloat(int parameterIndex) throws SQLException {
return getResult().getFloat(indexToOutputIndex(parameterIndex));
}
@Override
public double getDouble(int parameterIndex) throws SQLException {
return getResult().getDouble(indexToOutputIndex(parameterIndex));
}
@Override
public double getDouble(String parameterName) throws SQLException {
return getResult().getDouble(nameToOutputIndex(parameterName));
}
@Override
@SuppressWarnings("deprecation")
public BigDecimal getBigDecimal(int parameterIndex, int scale) throws SQLException {
return getResult().getBigDecimal(indexToOutputIndex(parameterIndex));
}
@Override
public BigDecimal getBigDecimal(int parameterIndex) throws SQLException {
return getResult().getBigDecimal(indexToOutputIndex(parameterIndex));
}
@Override
public BigDecimal getBigDecimal(String parameterName) throws SQLException {
return getResult().getBigDecimal(nameToOutputIndex(parameterName));
}
@Override
public byte[] getBytes(String parameterName) throws SQLException {
return getResult().getBytes(nameToOutputIndex(parameterName));
}
@Override
public byte[] getBytes(int parameterIndex) throws SQLException {
return getResult().getBytes(indexToOutputIndex(parameterIndex));
}
@Override
public Date getDate(int parameterIndex) throws SQLException {
return getResult().getDate(indexToOutputIndex(parameterIndex));
}
@Override
public Date getDate(String parameterName) throws SQLException {
return getResult().getDate(nameToOutputIndex(parameterName));
}
@Override
public Date getDate(String parameterName, Calendar cal) throws SQLException {
return getResult().getDate(nameToOutputIndex(parameterName), cal);
}
@Override
public Date getDate(int parameterIndex, Calendar cal) throws SQLException {
return getResult().getDate(parameterIndex, cal);
}
@Override
public Time getTime(int parameterIndex, Calendar cal) throws SQLException {
return getResult().getTime(indexToOutputIndex(parameterIndex), cal);
}
@Override
public Time getTime(String parameterName) throws SQLException {
return getResult().getTime(nameToOutputIndex(parameterName));
}
@Override
public Time getTime(String parameterName, Calendar cal) throws SQLException {
return getResult().getTime(nameToOutputIndex(parameterName), cal);
}
@Override
public Time getTime(int parameterIndex) throws SQLException {
return getResult().getTime(indexToOutputIndex(parameterIndex));
}
@Override
public Timestamp getTimestamp(int parameterIndex) throws SQLException {
return getResult().getTimestamp(parameterIndex);
}
@Override
public Timestamp getTimestamp(int parameterIndex, Calendar cal) throws SQLException {
return getResult().getTimestamp(indexToOutputIndex(parameterIndex), cal);
}
@Override
public Timestamp getTimestamp(String parameterName) throws SQLException {
return getResult().getTimestamp(nameToOutputIndex(parameterName));
}
@Override
public Timestamp getTimestamp(String parameterName, Calendar cal) throws SQLException {
return getResult().getTimestamp(nameToOutputIndex(parameterName), cal);
}
@Override
public Object getObject(int parameterIndex) throws SQLException {
return getResult().getObject(indexToOutputIndex(parameterIndex));
}
@Override
public Object getObject(int parameterIndex, Map> map) throws SQLException {
return getResult().getObject(indexToOutputIndex(parameterIndex), map);
}
@Override
public Object getObject(String parameterName) throws SQLException {
return getResult().getObject(nameToOutputIndex(parameterName));
}
@Override
public Object getObject(String parameterName, Map> map) throws SQLException {
return getResult().getObject(nameToOutputIndex(parameterName), map);
}
@Override
public T getObject(int parameterIndex, Class type) throws SQLException {
return getResult().getObject(indexToOutputIndex(parameterIndex), type);
}
@Override
public T getObject(String parameterName, Class type) throws SQLException {
return getResult().getObject(nameToOutputIndex(parameterName), type);
}
@Override
public Ref getRef(int parameterIndex) throws SQLException {
return getResult().getRef(indexToOutputIndex(parameterIndex));
}
@Override
public Ref getRef(String parameterName) throws SQLException {
return getResult().getRef(nameToOutputIndex(parameterName));
}
@Override
public Blob getBlob(int parameterIndex) throws SQLException {
return getResult().getBlob(parameterIndex);
}
@Override
public Blob getBlob(String parameterName) throws SQLException {
return getResult().getBlob(nameToOutputIndex(parameterName));
}
@Override
public Clob getClob(String parameterName) throws SQLException {
return getResult().getClob(nameToOutputIndex(parameterName));
}
@Override
public Clob getClob(int parameterIndex) throws SQLException {
return getResult().getClob(indexToOutputIndex(parameterIndex));
}
@Override
public Array getArray(String parameterName) throws SQLException {
return getResult().getArray(nameToOutputIndex(parameterName));
}
@Override
public Array getArray(int parameterIndex) throws SQLException {
return getResult().getArray(indexToOutputIndex(parameterIndex));
}
@Override
public URL getURL(int parameterIndex) throws SQLException {
return getResult().getURL(indexToOutputIndex(parameterIndex));
}
@Override
public URL getURL(String parameterName) throws SQLException {
return getResult().getURL(nameToOutputIndex(parameterName));
}
@Override
public RowId getRowId(int parameterIndex) throws SQLException {
throw ExceptionMapper.getFeatureNotSupportedException("RowIDs not supported");
}
@Override
public RowId getRowId(String parameterName) throws SQLException {
throw ExceptionMapper.getFeatureNotSupportedException("RowIDs not supported");
}
@Override
public NClob getNClob(int parameterIndex) throws SQLException {
return getResult().getNClob(indexToOutputIndex(parameterIndex));
}
@Override
public NClob getNClob(String parameterName) throws SQLException {
return getResult().getNClob(nameToOutputIndex(parameterName));
}
@Override
public SQLXML getSQLXML(int parameterIndex) throws SQLException {
throw ExceptionMapper.getFeatureNotSupportedException("SQLXML not supported");
}
@Override
public SQLXML getSQLXML(String parameterName) throws SQLException {
throw ExceptionMapper.getFeatureNotSupportedException("SQLXML not supported");
}
@Override
public String getNString(int parameterIndex) throws SQLException {
return getResult().getString(indexToOutputIndex(parameterIndex));
}
@Override
public String getNString(String parameterName) throws SQLException {
return getResult().getString(nameToOutputIndex(parameterName));
}
@Override
public Reader getNCharacterStream(int parameterIndex) throws SQLException {
return getResult().getCharacterStream(indexToOutputIndex(parameterIndex));
}
@Override
public Reader getNCharacterStream(String parameterName) throws SQLException {
return getResult().getCharacterStream(nameToOutputIndex(parameterName));
}
@Override
public Reader getCharacterStream(int parameterIndex) throws SQLException {
return getResult().getCharacterStream(indexToOutputIndex(parameterIndex));
}
@Override
public Reader getCharacterStream(String parameterName) throws SQLException {
return getResult().getCharacterStream(nameToOutputIndex(parameterName));
}
/**
* Registers the designated output parameter.
* This version of
* the method registerOutParameter
* should be used for a user-defined or REF
output parameter. Examples
* of user-defined types include: STRUCT
, DISTINCT
,
* JAVA_OBJECT
, and named array types.
*
* All OUT parameters must be registered
* before a stored procedure is executed.
* For a user-defined parameter, the fully-qualified SQL
* type name of the parameter should also be given, while a REF
* parameter requires that the fully-qualified type name of the
* referenced type be given. A JDBC driver that does not need the
* type code and type name information may ignore it. To be portable,
* however, applications should always provide these values for
* user-defined and REF
parameters.
*
* Although it is intended for user-defined and REF
parameters,
* this method may be used to register a parameter of any JDBC type.
* If the parameter does not have a user-defined or REF
type, the
* typeName parameter is ignored.
*
* Note: When reading the value of an out parameter, you
* must use the getter method whose Java type corresponds to the
* parameter's registered SQL type.
*
* @param parameterIndex the first parameter is 1, the second is 2,...
* @param sqlType a value from {@link Types}
* @param typeName the fully-qualified name of an SQL structured type
* @throws SQLException if the parameterIndex is not valid;
* if a database access error occurs or
* this method is called on a closed CallableStatement
* @throws SQLFeatureNotSupportedException if sqlType
is
* a ARRAY
, BLOB
, CLOB
,
* DATALINK
, JAVA_OBJECT
, NCHAR
,
* NCLOB
, NVARCHAR
, LONGNVARCHAR
,
* REF
, ROWID
, SQLXML
* or STRUCT
data type and the JDBC driver does not support
* this data type
* @see Types
*/
public void registerOutParameter(int parameterIndex, int sqlType, String typeName) throws SQLException {
CallParameter callParameter = getParameter(parameterIndex);
callParameter.sqlType = sqlType;
callParameter.typeName = typeName;
callParameter.isOutput = true;
}
@Override
public void registerOutParameter(int parameterIndex, int sqlType) throws SQLException {
registerOutParameter(parameterIndex, sqlType, -1);
}
/**
* Registers the parameter in ordinal position
* parameterIndex
to be of JDBC type
* sqlType
. All OUT parameters must be registered
* before a stored procedure is executed.
*
* The JDBC type specified by sqlType
for an OUT
* parameter determines the Java type that must be used
* in the get
method to read the value of that parameter.
*
* This version of registerOutParameter
should be
* used when the parameter is of JDBC type NUMERIC
* or DECIMAL
.
*
* @param parameterIndex the first parameter is 1, the second is 2,
* and so on
* @param sqlType the SQL type code defined by java.sql.Types
.
* @param scale the desired number of digits to the right of the
* decimal point. It must be greater than or equal to zero.
* @throws SQLException if the parameterIndex is not valid;
* if a database access error occurs or
* this method is called on a closed CallableStatement
* @throws SQLFeatureNotSupportedException if sqlType
is
* a ARRAY
, BLOB
, CLOB
,
* DATALINK
, JAVA_OBJECT
, NCHAR
,
* NCLOB
, NVARCHAR
, LONGNVARCHAR
,
* REF
, ROWID
, SQLXML
* or STRUCT
data type and the JDBC driver does not support
* this data type
* @see Types
*/
@Override
public void registerOutParameter(int parameterIndex, int sqlType, int scale) throws SQLException {
CallParameter callParameter = getParameter(parameterIndex);
callParameter.isOutput = true;
callParameter.outputSqlType = sqlType;
callParameter.scale = scale;
hasOutParameters = true;
}
@Override
public void registerOutParameter(String parameterName, int sqlType) throws SQLException {
registerOutParameter(nameToIndex(parameterName), sqlType);
}
@Override
public void registerOutParameter(String parameterName, int sqlType, int scale) throws SQLException {
registerOutParameter(nameToIndex(parameterName), sqlType, scale);
}
@Override
public void registerOutParameter(String parameterName, int sqlType, String typeName) throws SQLException {
registerOutParameter(nameToIndex(parameterName), sqlType, typeName);
}
CallParameter getParameter(int index) throws SQLException {
if (index > params.size() || index <= 0) {
throw new SQLException("No parameter with index " + (index));
}
return params.get(index - 1);
}
@Override
public void setSQLXML(String parameterName, SQLXML xmlObject) throws SQLException {
throw ExceptionMapper.getFeatureNotSupportedException("SQLXML not supported");
}
@Override
public void setRowId(String parameterName, RowId rowid) throws SQLException {
throw ExceptionMapper.getFeatureNotSupportedException("RowIDs not supported");
}
@Override
public void setNString(String parameterName, String value) throws SQLException {
setString(nameToIndex(parameterName), value);
}
@Override
public void setNCharacterStream(String parameterName, Reader value, long length) throws SQLException {
setCharacterStream(nameToIndex(parameterName), value, length);
}
@Override
public void setNCharacterStream(String parameterName, Reader value) throws SQLException {
setCharacterStream(nameToIndex(parameterName), value);
}
@Override
public void setNClob(String parameterName, NClob value) throws SQLException {
setClob(nameToIndex(parameterName), value);
}
@Override
public void setNClob(String parameterName, Reader reader, long length) throws SQLException {
setClob(nameToIndex(parameterName), reader, length);
}
@Override
public void setNClob(String parameterName, Reader reader) throws SQLException {
setClob(nameToIndex(parameterName), reader);
}
@Override
public void setClob(String parameterName, Reader reader, long length) throws SQLException {
setClob(nameToIndex(parameterName), reader, length);
}
@Override
public void setClob(String parameterName, Clob clob) throws SQLException {
setClob(nameToIndex(parameterName), clob);
}
@Override
public void setClob(String parameterName, Reader reader) throws SQLException {
setClob(nameToIndex(parameterName), reader);
}
@Override
public void setBlob(String parameterName, InputStream inputStream, long length) throws SQLException {
setBlob(nameToIndex(parameterName), inputStream, length);
}
@Override
public void setBlob(String parameterName, Blob blob) throws SQLException {
setBlob(nameToIndex(parameterName), blob);
}
@Override
public void setBlob(String parameterName, InputStream inputStream) throws SQLException {
setBlob(nameToIndex(parameterName), inputStream);
}
@Override
public void setAsciiStream(String parameterName, InputStream inputStream, long length) throws SQLException {
setAsciiStream(nameToIndex(parameterName), inputStream, length);
}
@Override
public void setAsciiStream(String parameterName, InputStream inputStream, int length) throws SQLException {
setAsciiStream(nameToIndex(parameterName), inputStream, length);
}
@Override
public void setAsciiStream(String parameterName, InputStream inputStream) throws SQLException {
setAsciiStream(nameToIndex(parameterName), inputStream);
}
@Override
public void setBinaryStream(String parameterName, InputStream inputStream, long length) throws SQLException {
setBinaryStream(nameToIndex(parameterName), inputStream, length);
}
@Override
public void setBinaryStream(String parameterName, InputStream inputStream) throws SQLException {
setBinaryStream(nameToIndex(parameterName), inputStream);
}
@Override
public void setBinaryStream(String parameterName, InputStream inputStream, int length) throws SQLException {
setBinaryStream(nameToIndex(parameterName), inputStream, length);
}
@Override
public void setCharacterStream(String parameterName, Reader reader, long length) throws SQLException {
setCharacterStream(nameToIndex(parameterName), reader, length);
}
@Override
public void setCharacterStream(String parameterName, Reader reader) throws SQLException {
setCharacterStream(nameToIndex(parameterName), reader);
}
@Override
public void setCharacterStream(String parameterName, Reader reader, int length) throws SQLException {
setCharacterStream(nameToIndex(parameterName), reader, length);
}
@Override
public void setURL(String parameterName, URL url) throws SQLException {
setURL(nameToIndex(parameterName), url);
}
@Override
public void setNull(String parameterName, int sqlType) throws SQLException {
setNull(nameToIndex(parameterName), sqlType);
}
@Override
public void setNull(String parameterName, int sqlType, String typeName) throws SQLException {
setNull(nameToIndex(parameterName), sqlType, typeName);
}
@Override
public void setBoolean(String parameterName, boolean booleanValue) throws SQLException {
setBoolean(nameToIndex(parameterName), booleanValue);
}
@Override
public void setByte(String parameterName, byte byteValue) throws SQLException {
setByte(nameToIndex(parameterName), byteValue);
}
@Override
public void setShort(String parameterName, short shortValue) throws SQLException {
setShort(nameToIndex(parameterName), shortValue);
}
@Override
public void setInt(String parameterName, int intValue) throws SQLException {
setInt(nameToIndex(parameterName), intValue);
}
@Override
public void setLong(String parameterName, long longValue) throws SQLException {
setLong(nameToIndex(parameterName), longValue);
}
@Override
public void setFloat(String parameterName, float floatValue) throws SQLException {
setFloat(nameToIndex(parameterName), floatValue);
}
@Override
public void setDouble(String parameterName, double doubleValue) throws SQLException {
setDouble(nameToIndex(parameterName), doubleValue);
}
@Override
public void setBigDecimal(String parameterName, BigDecimal bigDecimal) throws SQLException {
setBigDecimal(nameToIndex(parameterName), bigDecimal);
}
@Override
public void setString(String parameterName, String stringValue) throws SQLException {
setString(nameToIndex(parameterName), stringValue);
}
@Override
public void setBytes(String parameterName, byte[] bytes) throws SQLException {
setBytes(nameToIndex(parameterName), bytes);
}
@Override
public void setDate(String parameterName, Date date) throws SQLException {
setDate(nameToIndex(parameterName), date);
}
@Override
public void setDate(String parameterName, Date date, Calendar cal) throws SQLException {
setDate(nameToIndex(parameterName), date, cal);
}
@Override
public void setTime(String parameterName, Time time) throws SQLException {
setTime(nameToIndex(parameterName), time);
}
@Override
public void setTime(String parameterName, Time time, Calendar cal) throws SQLException {
setTime(nameToIndex(parameterName), time, cal);
}
@Override
public void setTimestamp(String parameterName, Timestamp timestamp) throws SQLException {
setTimestamp(nameToIndex(parameterName), timestamp);
}
@Override
public void setTimestamp(String parameterName, Timestamp timestamp, Calendar cal) throws SQLException {
setTimestamp(nameToIndex(parameterName), timestamp, cal);
}
@Override
public void setObject(String parameterName, Object obj, int targetSqlType, int scale) throws SQLException {
setObject(nameToIndex(parameterName), obj, targetSqlType, scale);
}
@Override
public void setObject(String parameterName, Object obj, int targetSqlType) throws SQLException {
setObject(nameToIndex(parameterName), obj, targetSqlType);
}
@Override
public void setObject(String parameterName, Object obj) throws SQLException {
setObject(nameToIndex(parameterName), obj);
}
@Override
protected boolean isNoBackslashEscapes() {
return connection.noBackslashEscapes;
}
@Override
protected boolean useFractionalSeconds() {
return useFractionalSeconds;
}
}