/* Copyright (C) 2009 Volker Berlin (i-net software) This software is provided 'as-is', without any express or implied warranty. In no event will the authors be held liable for any damages arising from the use of this software. Permission is granted to anyone to use this software for any purpose, including commercial applications, and to alter it and redistribute it freely, subject to the following restrictions: 1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required. 2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software. 3. This notice may not be removed or altered from any source distribution. Jeroen Frijters jeroen@frijters.net */ package sun.jdbc.odbc; 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.Map; import cli.System.Data.*; import cli.System.Data.Common.*; import cli.System.Data.Odbc.*; /** * @author Volker Berlin */ public class JdbcOdbcCallableStatement extends JdbcOdbcPreparedStatement implements CallableStatement{ private final Parameters parameters = new Parameters(); public JdbcOdbcCallableStatement(JdbcOdbcConnection jdbcConn, OdbcCommand command, String sql, int resultSetType, int resultSetConcurrency){ super(jdbcConn, command, sql, resultSetType, resultSetConcurrency); } public final Array getArray(int parameterIndex){ return parameters.getArray(parameterIndex); } public final Array getArray(String parameterName) throws SQLException{ return parameters.getArray(parameterName); } public final BigDecimal getBigDecimal(int parameterIndex, int scale) throws SQLException{ return parameters.getBigDecimal(parameterIndex, scale); } public final BigDecimal getBigDecimal(int parameterIndex) throws SQLException{ return parameters.getBigDecimal(parameterIndex); } public final BigDecimal getBigDecimal(String parameterName) throws SQLException{ return parameters.getBigDecimal(parameterName); } public final Blob getBlob(int parameterIndex){ return parameters.getBlob(parameterIndex); } public final Blob getBlob(String parameterName) throws SQLException{ return parameters.getBlob(parameterName); } public final boolean getBoolean(int parameterIndex) throws SQLException{ return parameters.getBoolean(parameterIndex); } public final boolean getBoolean(String parameterName) throws SQLException{ return parameters.getBoolean(parameterName); } public final byte getByte(int parameterIndex) throws SQLException{ return parameters.getByte(parameterIndex); } public final byte getByte(String parameterName) throws SQLException{ return parameters.getByte(parameterName); } public final byte[] getBytes(int parameterIndex) throws SQLException{ return parameters.getBytes(parameterIndex); } public final byte[] getBytes(String parameterName) throws SQLException{ return parameters.getBytes(parameterName); } public final Reader getCharacterStream(int parameterIndex) throws SQLException{ return parameters.getCharacterStream(parameterIndex); } public final Reader getCharacterStream(String parameterName) throws SQLException{ return parameters.getCharacterStream(parameterName); } public final Clob getClob(int parameterIndex){ return parameters.getClob(parameterIndex); } public final Clob getClob(String parameterName) throws SQLException{ return parameters.getClob(parameterName); } public final Date getDate(int parameterIndex, Calendar cal) throws SQLException{ return parameters.getDate(parameterIndex, cal); } public final Date getDate(int parameterIndex) throws SQLException{ return parameters.getDate(parameterIndex); } public final Date getDate(String parameterName, Calendar cal) throws SQLException{ return parameters.getDate(parameterName, cal); } public final Date getDate(String parameterName) throws SQLException{ return parameters.getDate(parameterName); } public final double getDouble(int parameterIndex) throws SQLException{ return parameters.getDouble(parameterIndex); } public final double getDouble(String parameterName) throws SQLException{ return parameters.getDouble(parameterName); } public final float getFloat(int parameterIndex) throws SQLException{ return parameters.getFloat(parameterIndex); } public final float getFloat(String parameterName) throws SQLException{ return parameters.getFloat(parameterName); } public final int getInt(int parameterIndex) throws SQLException{ return parameters.getInt(parameterIndex); } public final int getInt(String parameterName) throws SQLException{ return parameters.getInt(parameterName); } public final long getLong(int parameterIndex) throws SQLException{ return parameters.getLong(parameterIndex); } public final long getLong(String parameterName) throws SQLException{ return parameters.getLong(parameterName); } public final Reader getNCharacterStream(int parameterIndex) throws SQLException{ return parameters.getNCharacterStream(parameterIndex); } public final Reader getNCharacterStream(String parameterName) throws SQLException{ return parameters.getNCharacterStream(parameterName); } public final NClob getNClob(int parameterIndex){ return parameters.getNClob(parameterIndex); } public final NClob getNClob(String parameterName) throws SQLException{ return parameters.getNClob(parameterName); } public final String getNString(int parameterIndex) throws SQLException{ return parameters.getNString(parameterIndex); } public final String getNString(String parameterName) throws SQLException{ return parameters.getNString(parameterName); } public final Object getObject(int parameterIndex, Map<String, Class<?>> map){ return parameters.getObject(parameterIndex, map); } public final Object getObject(int parameterIndex) throws SQLException{ return parameters.getObject(parameterIndex); } public final Object getObject(String parameterName, Map<String, Class<?>> map) throws SQLException{ return parameters.getObject(parameterName, map); } public final Object getObject(String parameterName) throws SQLException{ return parameters.getObject(parameterName); } public final Ref getRef(int parameterIndex){ return parameters.getRef(parameterIndex); } public final Ref getRef(String parameterName) throws SQLException{ return parameters.getRef(parameterName); } public final RowId getRowId(int parameterIndex){ return parameters.getRowId(parameterIndex); } public final RowId getRowId(String parameterName) throws SQLException{ return parameters.getRowId(parameterName); } public final short getShort(int parameterIndex) throws SQLException{ return parameters.getShort(parameterIndex); } public final short getShort(String parameterName) throws SQLException{ return parameters.getShort(parameterName); } public final SQLXML getSQLXML(int parameterIndex){ return parameters.getSQLXML(parameterIndex); } public final SQLXML getSQLXML(String parameterName) throws SQLException{ return parameters.getSQLXML(parameterName); } public final String getString(int parameterIndex) throws SQLException{ return parameters.getString(parameterIndex); } public final String getString(String parameterName) throws SQLException{ return parameters.getString(parameterName); } public final Time getTime(int parameterIndex, Calendar cal) throws SQLException{ return parameters.getTime(parameterIndex, cal); } public final Time getTime(int parameterIndex) throws SQLException{ return parameters.getTime(parameterIndex); } public final Time getTime(String parameterName, Calendar cal) throws SQLException{ return parameters.getTime(parameterName, cal); } public final Time getTime(String parameterName) throws SQLException{ return parameters.getTime(parameterName); } public final Timestamp getTimestamp(int parameterIndex, Calendar cal) throws SQLException{ return parameters.getTimestamp(parameterIndex, cal); } public final Timestamp getTimestamp(int parameterIndex) throws SQLException{ return parameters.getTimestamp(parameterIndex); } public final Timestamp getTimestamp(String parameterName, Calendar cal) throws SQLException{ return parameters.getTimestamp(parameterName, cal); } public final Timestamp getTimestamp(String parameterName) throws SQLException{ return parameters.getTimestamp(parameterName); } public final URL getURL(int parameterIndex) throws SQLException{ return parameters.getURL(parameterIndex); } public final URL getURL(String parameterName) throws SQLException{ return parameters.getURL(parameterName); } public final boolean wasNull(){ return parameters.wasNull(); } public void registerOutParameter(int parameterIndex, int sqlType) throws SQLException{ registerOutParameter(parameterIndex, sqlType, -1); } public void registerOutParameter(String parameterName, int sqlType) throws SQLException{ registerOutParameter(parameters.findColumn(parameterName), sqlType); } public void registerOutParameter(int parameterIndex, int sqlType, int scaleOrLength) throws SQLException{ DbParameter para = getPara(parameterIndex); int direction = para.get_Value() == null ? ParameterDirection.Output : ParameterDirection.InputOutput; para.set_Direction(ParameterDirection.wrap(direction)); if(sqlType != Types.OTHER){ para.set_DbType(DbType.wrap(JdbcOdbcUtils.convertJdbc2AdoNetType(sqlType))); } if(scaleOrLength >= 0){ switch(sqlType){ case Types.DECIMAL: case Types.NUMERIC: para.set_Scale((byte)scaleOrLength); } } } public void registerOutParameter(int parameterIndex, int sqlType, String typeName){ throw new UnsupportedOperationException(); } public void registerOutParameter(String parameterName, int sqlType, int scale) throws SQLException{ registerOutParameter(parameters.findColumn(parameterName), sqlType, scale); } public void registerOutParameter(String parameterName, int sqlType, String typeName) throws SQLException{ registerOutParameter(parameters.findColumn(parameterName), sqlType, typeName); } public void setAsciiStream(String parameterName, InputStream x) throws SQLException{ setAsciiStream(parameters.findColumn(parameterName), x); } public void setAsciiStream(String parameterName, InputStream x, int length) throws SQLException{ setAsciiStream(parameters.findColumn(parameterName), x, length); } public void setAsciiStream(String parameterName, InputStream x, long length) throws SQLException{ setAsciiStream(parameters.findColumn(parameterName), x, length); } public void setBigDecimal(String parameterName, BigDecimal x) throws SQLException{ setBigDecimal(parameters.findColumn(parameterName), x); } public void setBinaryStream(String parameterName, InputStream x) throws SQLException{ setBinaryStream(parameters.findColumn(parameterName), x); } public void setBinaryStream(String parameterName, InputStream x, int length) throws SQLException{ setBinaryStream(parameters.findColumn(parameterName), x, length); } public void setBinaryStream(String parameterName, InputStream x, long length) throws SQLException{ setBinaryStream(parameters.findColumn(parameterName), x, length); } public void setBlob(String parameterName, Blob x) throws SQLException{ setBlob(parameters.findColumn(parameterName), x); } public void setBlob(String parameterName, InputStream x) throws SQLException{ setBlob(parameters.findColumn(parameterName), x); } public void setBlob(String parameterName, InputStream x, long length) throws SQLException{ setBlob(parameters.findColumn(parameterName), x, length); } public void setBoolean(String parameterName, boolean x) throws SQLException{ setBoolean(parameters.findColumn(parameterName), x); } public void setByte(String parameterName, byte x) throws SQLException{ setByte(parameters.findColumn(parameterName), x); } public void setBytes(String parameterName, byte[] x) throws SQLException{ setBytes(parameters.findColumn(parameterName), x); } public void setCharacterStream(String parameterName, Reader x) throws SQLException{ setCharacterStream(parameters.findColumn(parameterName), x); } public void setCharacterStream(String parameterName, Reader x, int length) throws SQLException{ setCharacterStream(parameters.findColumn(parameterName), x, length); } public void setCharacterStream(String parameterName, Reader x, long length) throws SQLException{ setCharacterStream(parameters.findColumn(parameterName), x, length); } public void setClob(String parameterName, Clob x) throws SQLException{ setClob(parameters.findColumn(parameterName), x); } public void setClob(String parameterName, Reader x) throws SQLException{ setClob(parameters.findColumn(parameterName), x); } public void setClob(String parameterName, Reader x, long length) throws SQLException{ setClob(parameters.findColumn(parameterName), x, length); } public void setDate(String parameterName, Date x) throws SQLException{ setDate(parameters.findColumn(parameterName), x); } public void setDate(String parameterName, Date x, Calendar cal) throws SQLException{ setDate(parameters.findColumn(parameterName), x, cal); } public void setDouble(String parameterName, double x) throws SQLException{ setDouble(parameters.findColumn(parameterName), x); } public void setFloat(String parameterName, float x) throws SQLException{ setFloat(parameters.findColumn(parameterName), x); } public void setInt(String parameterName, int x) throws SQLException{ setInt(parameters.findColumn(parameterName), x); } public void setLong(String parameterName, long x) throws SQLException{ setLong(parameters.findColumn(parameterName), x); } public void setNCharacterStream(String parameterName, Reader x) throws SQLException{ setNCharacterStream(parameters.findColumn(parameterName), x); } public void setNCharacterStream(String parameterName, Reader x, long length) throws SQLException{ setNCharacterStream(parameters.findColumn(parameterName), x, length); } public void setNClob(String parameterName, NClob x) throws SQLException{ setNClob(parameters.findColumn(parameterName), x); } public void setNClob(String parameterName, Reader x) throws SQLException{ setNClob(parameters.findColumn(parameterName), x); } public void setNClob(String parameterName, Reader x, long length) throws SQLException{ setNClob(parameters.findColumn(parameterName), x, length); } public void setNString(String parameterName, String x) throws SQLException{ setNString(parameters.findColumn(parameterName), x); } public void setNull(String parameterName, int sqlType) throws SQLException{ setNull(parameters.findColumn(parameterName), sqlType); } public void setNull(String parameterName, int sqlType, String typeName) throws SQLException{ setNull(parameters.findColumn(parameterName), sqlType, typeName); } public void setObject(String parameterName, Object x) throws SQLException{ setObject(parameters.findColumn(parameterName), x); } public void setObject(String parameterName, Object x, int targetSqlType) throws SQLException{ setObject(parameters.findColumn(parameterName), x, targetSqlType); } public void setObject(String parameterName, Object x, int targetSqlType, int scaleOrLength) throws SQLException{ setObject(parameters.findColumn(parameterName), x, targetSqlType, scaleOrLength); } public void setRowId(String parameterName, RowId x) throws SQLException{ setRowId(parameters.findColumn(parameterName), x); } public void setSQLXML(String parameterName, SQLXML x) throws SQLException{ setSQLXML(parameters.findColumn(parameterName), x); } public void setShort(String parameterName, short x) throws SQLException{ setShort(parameters.findColumn(parameterName), x); } public void setString(String parameterName, String x) throws SQLException{ setString(parameters.findColumn(parameterName), x); } public void setTime(String parameterName, Time x) throws SQLException{ setTime(parameters.findColumn(parameterName), x); } public void setTime(String parameterName, Time x, Calendar cal) throws SQLException{ setTime(parameters.findColumn(parameterName), x, cal); } public void setTimestamp(String parameterName, Timestamp x) throws SQLException{ setTimestamp(parameters.findColumn(parameterName), x); } public void setTimestamp(String parameterName, Timestamp x, Calendar cal) throws SQLException{ setTimestamp(parameters.findColumn(parameterName), x, cal); } public void setURL(String parameterName, URL x) throws SQLException{ setURL(parameters.findColumn(parameterName), x); } private class Parameters extends JdbcOdbcObject{ @Override public int findColumn(String parameterName) throws SQLException{ try{ DbParameterCollection params = command.get_Parameters(); for(int i=0; i<params.get_Count();i++){ DbParameter param = params.get_Item(i); if(parameterName.equalsIgnoreCase(param.get_ParameterName())){ return i+1; } } throw new SQLException( "Parameter '"+parameterName+"' not found.", "S0022"); }catch(Throwable th){ throw JdbcOdbcUtils.createSQLException(th); } } @Override protected Object getObjectImpl(int parameterIndex) throws SQLException{ return getPara(parameterIndex).get_Value(); } } }