Java程序  |  968行  |  26.11 KB

package SQLite.JDBC2z;

import java.sql.*;
import java.math.BigDecimal;
import java.util.*;

class BatchArg {
    String arg;
    boolean blob;

    BatchArg(String arg, boolean blob) {
	if (arg == null) {
	    this.arg = null;
	} else {
	    this.arg = new String(arg);
	}
	this.blob = blob;
    }
}

public class JDBCPreparedStatement extends JDBCStatement
    implements java.sql.PreparedStatement {

    private String sql;
    private String args[];
    private boolean blobs[];
    private ArrayList<BatchArg> batch;
    private static final boolean nullrepl =
	SQLite.Database.version().compareTo("2.5.0") < 0;

    public JDBCPreparedStatement(JDBCConnection conn, String sql) {
	super(conn);
	this.args = null;
	this.blobs = null;
	this.batch = null;
	this.sql = fixup(sql);
    }

    private String fixup(String sql) {
	StringBuffer sb = new StringBuffer();
	boolean inq = false;
	int nparm = 0;
	for (int i = 0; i < sql.length(); i++) {
	    char c = sql.charAt(i);
	    if (c == '\'') {
		if (inq) {
                    char nextChar = 0;
                    if(i + 1 < sql.length()) {
                        nextChar = sql.charAt(i + 1);
                    }
		    if (nextChar == '\'') {
                        sb.append(c);
                        sb.append(nextChar);
                        i++;
                    } else {
			inq = false;
                        sb.append(c);
                    }
		} else {
		    inq = true;
                    sb.append(c);
		}
	    } else if (c == '?') {
		if (inq) {
		    sb.append(c);
		} else {
		    ++nparm;
		    sb.append(nullrepl ? "'%q'" : "%Q");
		}
	    } else if (c == ';') {
		if (!inq) {
		    break;
		}
		sb.append(c);
	    } else if (c == '%') {
		sb.append("%%");
	    } else {
		sb.append(c);
	    }
	}
	args = new String[nparm];
	blobs = new boolean[nparm];
	try {
	    clearParameters();
	} catch (SQLException e) {
	}
	return sb.toString();
    }

    private String fixup2(String sql) {
	if (!conn.db.is3()) {
	    return sql;
	}
	StringBuffer sb = new StringBuffer();
	int parm = -1;
	for (int i = 0; i < sql.length(); i++) {
	    char c = sql.charAt(i);
	    if (c == '%') {
		sb.append(c);
		++i;
		c = sql.charAt(i);
		if (c == 'Q') {
		    parm++;
		    if (blobs[parm]) {
			c = 's';
		    }
		}
	    }
	    sb.append(c);
	}
	return sb.toString();
    }

    public ResultSet executeQuery() throws SQLException {
	return executeQuery(fixup2(sql), args, false);
    }

    public int executeUpdate() throws SQLException {
	executeQuery(fixup2(sql), args, true);
	return updcnt;
    }

    public void setNull(int parameterIndex, int sqlType) throws SQLException {
	if (parameterIndex < 1 || parameterIndex > args.length) {
	    throw new SQLException("bad parameter index");
	}
	args[parameterIndex - 1] = nullrepl ? "" : null;
	blobs[parameterIndex - 1] = false;
    }
    
    public void setBoolean(int parameterIndex, boolean x)
	throws SQLException {
	if (parameterIndex < 1 || parameterIndex > args.length) {
	    throw new SQLException("bad parameter index");
	}
	args[parameterIndex - 1] = x ? "1" : "0";
	blobs[parameterIndex - 1] = false;
    }

    public void setByte(int parameterIndex, byte x) throws SQLException {
	if (parameterIndex < 1 || parameterIndex > args.length) {
	    throw new SQLException("bad parameter index");
	}
	args[parameterIndex - 1] = "" + x;
	blobs[parameterIndex - 1] = false;
    }

    public void setShort(int parameterIndex, short x) throws SQLException {
	if (parameterIndex < 1 || parameterIndex > args.length) {
	    throw new SQLException("bad parameter index");
	}
	args[parameterIndex - 1] = "" + x;
	blobs[parameterIndex - 1] = false;
    }

    public void setInt(int parameterIndex, int x) throws SQLException {
	if (parameterIndex < 1 || parameterIndex > args.length) {
	    throw new SQLException("bad parameter index");
	}
	args[parameterIndex - 1] = "" + x;
	blobs[parameterIndex - 1] = false;
    }

    public void setLong(int parameterIndex, long x) throws SQLException {
	if (parameterIndex < 1 || parameterIndex > args.length) {
	    throw new SQLException("bad parameter index");
	}
	args[parameterIndex - 1] = "" + x;
	blobs[parameterIndex - 1] = false;
    }

    public void setFloat(int parameterIndex, float x) throws SQLException {
	if (parameterIndex < 1 || parameterIndex > args.length) {
	    throw new SQLException("bad parameter index");
	}
	args[parameterIndex - 1] = "" + x;
	blobs[parameterIndex - 1] = false;
    }

    public void setDouble(int parameterIndex, double x) throws SQLException {
	if (parameterIndex < 1 || parameterIndex > args.length) {
	    throw new SQLException("bad parameter index");
	}
	args[parameterIndex - 1] = "" + x;
	blobs[parameterIndex - 1] = false;
    }

    public void setBigDecimal(int parameterIndex, BigDecimal x)
	throws SQLException {
	if (parameterIndex < 1 || parameterIndex > args.length) {
	    throw new SQLException("bad parameter index");
	}
	if (x == null) {
	    args[parameterIndex - 1] = nullrepl ? "" : null;
	} else {
	    args[parameterIndex - 1] = "" + x;
	}
	blobs[parameterIndex - 1] = false;
    }

    public void setString(int parameterIndex, String x) throws SQLException {
	if (parameterIndex < 1 || parameterIndex > args.length) {
	    throw new SQLException("bad parameter index");
	}
	if (x == null) {
	    args[parameterIndex - 1] = nullrepl ? "" : null;
	} else {
	    args[parameterIndex - 1] = x;
	}
	blobs[parameterIndex - 1] = false;
    }

    public void setBytes(int parameterIndex, byte x[]) throws SQLException {
	if (parameterIndex < 1 || parameterIndex > args.length) {
	    throw new SQLException("bad parameter index");
	}
	blobs[parameterIndex - 1] = false;
	if (x == null) {
	    args[parameterIndex - 1] = nullrepl ? "" : null;
	} else {
	    if (conn.db.is3()) {
		args[parameterIndex - 1] = SQLite.StringEncoder.encodeX(x);
		blobs[parameterIndex - 1] = true;
	    } else {
		args[parameterIndex - 1] = SQLite.StringEncoder.encode(x);
	    }
	}
    }

    public void setDate(int parameterIndex, java.sql.Date x)
	throws SQLException {
	if (parameterIndex < 1 || parameterIndex > args.length) {
	    throw new SQLException("bad parameter index");
	}
	if (x == null) {
	    args[parameterIndex - 1] = nullrepl ? "" : null;
	} else {
	    if (conn.useJulian) {
		args[parameterIndex - 1] = java.lang.Double.toString(SQLite.Database.julian_from_long(x.getTime()));
	    } else {
		args[parameterIndex - 1] = x.toString();
	    }
	}
	blobs[parameterIndex - 1] = false;
    }

    public void setTime(int parameterIndex, java.sql.Time x) 
	throws SQLException {
	if (parameterIndex < 1 || parameterIndex > args.length) {
	    throw new SQLException("bad parameter index");
	}
	if (x == null) {
	    args[parameterIndex - 1] = nullrepl ? "" : null;
	} else {
	    if (conn.useJulian) {
		args[parameterIndex - 1] = java.lang.Double.toString(SQLite.Database.julian_from_long(x.getTime()));
	    } else {
		args[parameterIndex - 1] = x.toString();
	    }
	}
	blobs[parameterIndex - 1] = false;
    }

    public void setTimestamp(int parameterIndex, java.sql.Timestamp x)
	throws SQLException {
	if (parameterIndex < 1 || parameterIndex > args.length) {
	    throw new SQLException("bad parameter index");
	}
	if (x == null) {
	    args[parameterIndex - 1] = nullrepl ? "" : null;
	} else {
	    if (conn.useJulian) {
		args[parameterIndex - 1] = java.lang.Double.toString(SQLite.Database.julian_from_long(x.getTime()));
	    } else {
		args[parameterIndex - 1] = x.toString();
	    }
	}
	blobs[parameterIndex - 1] = false;
    }

    public void setAsciiStream(int parameterIndex, java.io.InputStream x,
			       int length) throws SQLException {
	throw new SQLException("not supported");
    }

    @Deprecated
    public void setUnicodeStream(int parameterIndex, java.io.InputStream x, 
				 int length) throws SQLException {
	throw new SQLFeatureNotSupportedException();
    }

    public void setBinaryStream(int parameterIndex, java.io.InputStream x,
				int length) throws SQLException {
	try {
	    byte[] data = new byte[length];
	    x.read(data, 0, length);
	    setBytes(parameterIndex, data);
	} catch (java.io.IOException e) {
	    throw new SQLException("I/O failed");
	}
    }

    public void clearParameters() throws SQLException {
	for (int i = 0; i < args.length; i++) {
	    args[i] = nullrepl ? "" : null;
	    blobs[i] = false;
	}
    }

    public void setObject(int parameterIndex, Object x, int targetSqlType,
			  int scale) throws SQLException {
	if (parameterIndex < 1 || parameterIndex > args.length) {
	    throw new SQLException("bad parameter index");
	}
	if (x == null) {
	    args[parameterIndex - 1] = nullrepl ? "" : null;
	} else {
	    if (x instanceof byte[]) {
		byte[] bx = (byte[]) x;
		if (conn.db.is3()) {
		    args[parameterIndex - 1] =
			  SQLite.StringEncoder.encodeX(bx);
		    blobs[parameterIndex - 1] = true;
		    return;
		}
		args[parameterIndex - 1] = SQLite.StringEncoder.encode(bx);
	    } else {
		args[parameterIndex - 1] = x.toString();
	    }
	}
	blobs[parameterIndex - 1] = false;
    }

    public void setObject(int parameterIndex, Object x, int targetSqlType)
	throws SQLException {
	if (parameterIndex < 1 || parameterIndex > args.length) {
	    throw new SQLException("bad parameter index");
	}
	if (x == null) {
	    args[parameterIndex - 1] = nullrepl ? "" : null;
	} else {
	    if (x instanceof byte[]) {
		byte[] bx = (byte[]) x;
		if (conn.db.is3()) {
		    args[parameterIndex - 1] =
			SQLite.StringEncoder.encodeX(bx);
		    blobs[parameterIndex - 1] = true;
		    return;
		}
		args[parameterIndex - 1] = SQLite.StringEncoder.encode(bx);
	    } else {
		args[parameterIndex - 1] = x.toString();
	    }
	}
	blobs[parameterIndex - 1] = false;
    }

    public void setObject(int parameterIndex, Object x) throws SQLException {
	if (parameterIndex < 1 || parameterIndex > args.length) {
	    throw new SQLException("bad parameter index");
	}
	if (x == null) {
	    args[parameterIndex - 1] = nullrepl ? "" : null;
	} else {
	    if (x instanceof byte[]) {
		byte[] bx = (byte[]) x;
		if (conn.db.is3()) {
		    args[parameterIndex - 1] =
			SQLite.StringEncoder.encodeX(bx);
		    blobs[parameterIndex - 1] = true;
		    return;
		}
		args[parameterIndex - 1] = SQLite.StringEncoder.encode(bx);
	    } else {
		args[parameterIndex - 1] = x.toString();
	    }
	}
	blobs[parameterIndex - 1] = false;
    }

    public boolean execute() throws SQLException {
	return executeQuery(fixup2(sql), args, false) != null;
    }

    public void addBatch() throws SQLException {
	if (batch == null) {
	    batch = new ArrayList<BatchArg>(args.length);
	}
	for (int i = 0; i < args.length; i++) {
	    batch.add(new BatchArg(args[i], blobs[i]));
	}
    }

    public int[] executeBatch() throws SQLException {
	if (batch == null) {
	    return new int[0];
	}
	int[] ret = new int[batch.size() / args.length];
	for (int i = 0; i < ret.length; i++) {
	    ret[i] = EXECUTE_FAILED;
	}
	int errs = 0;
	int index = 0;
	for (int i = 0; i < ret.length; i++) {
	    for (int k = 0; k < args.length; k++) {
		BatchArg b = (BatchArg) batch.get(index++);

		args[k] = b.arg;
		blobs[k] = b.blob;
	    }
	    try {
		ret[i] = executeUpdate();
	    } catch (SQLException e) {
		++errs;
	    }
	}
	if (errs > 0) {
	    throw new BatchUpdateException("batch failed", ret);
	}
	return ret;
    }

    public void clearBatch() throws SQLException {
	if (batch != null) {
	    batch.clear();
	    batch = null;
	}
    }

    public void close() throws SQLException {
    	clearBatch();
	super.close();
    }

    public void setCharacterStream(int parameterIndex,
				   java.io.Reader reader,
				   int length) throws SQLException {
	try {
	    char[] data = new char[length];
	    reader.read(data);
	    setString(parameterIndex, new String(data));
	} catch (java.io.IOException e) {
	    throw new SQLException("I/O failed");
	}
    }

    public void setRef(int i, Ref x) throws SQLException {
	throw new SQLFeatureNotSupportedException();
    }

    public void setBlob(int i, Blob x) throws SQLException {
	throw new SQLFeatureNotSupportedException();
    }

    public void setClob(int i, Clob x) throws SQLException {
	throw new SQLFeatureNotSupportedException();
    }

    public void setArray(int i, Array x) throws SQLException {
	throw new SQLFeatureNotSupportedException();
    }

    public ResultSetMetaData getMetaData() throws SQLException {
	return rs.getMetaData();
    }

    public void setDate(int parameterIndex, java.sql.Date x, Calendar cal)
	throws SQLException {
	setDate(parameterIndex, x);
    }

    public void setTime(int parameterIndex, java.sql.Time x, Calendar cal)
	throws SQLException {
	setTime(parameterIndex, x);
    }

    public void setTimestamp(int parameterIndex, java.sql.Timestamp x,
			     Calendar cal) throws SQLException {
	setTimestamp(parameterIndex, x);
    }

    public void setNull(int parameterIndex, int sqlType, String typeName)
	throws SQLException {
	setNull(parameterIndex, sqlType);
    }

    public ParameterMetaData getParameterMetaData() throws SQLException {
	throw new SQLException("not supported");
    }

    public void registerOutputParameter(String parameterName, int sqlType)
	throws SQLException {
	throw new SQLException("not supported");
    }

    public void registerOutputParameter(String parameterName, int sqlType,
					int scale)
	throws SQLException {
	throw new SQLException("not supported");
    }

    public void registerOutputParameter(String parameterName, int sqlType,
					String typeName)
	throws SQLException {
	throw new SQLException("not supported");
    }

    public java.net.URL getURL(int parameterIndex) throws SQLException {
	throw new SQLException("not supported");
    }

    public void setURL(int parameterIndex, java.net.URL url)
	throws SQLException {
	throw new SQLException("not supported");
    }

    public void setNull(String parameterName, int sqlType)
	throws SQLException {
	throw new SQLException("not supported");
    }

    public void setBoolean(String parameterName, boolean val)
	throws SQLException {
	throw new SQLException("not supported");
    }

    public void setByte(String parameterName, byte val)
	throws SQLException {
	throw new SQLException("not supported");
    }

    public void setShort(String parameterName, short val)
	throws SQLException {
	throw new SQLException("not supported");
    }

    public void setInt(String parameterName, int val)
	throws SQLException {
	throw new SQLException("not supported");
    }

    public void setLong(String parameterName, long val)
	throws SQLException {
	throw new SQLException("not supported");
    }

    public void setFloat(String parameterName, float val)
	throws SQLException {
	throw new SQLException("not supported");
    }

    public void setDouble(String parameterName, double val)
	throws SQLException {
	throw new SQLException("not supported");
    }

    public void setBigDecimal(String parameterName, BigDecimal val)
	throws SQLException {
	throw new SQLException("not supported");
    }

    public void setString(String parameterName, String val)
	throws SQLException {
	throw new SQLException("not supported");
    }

    public void setBytes(String parameterName, byte val[])
	throws SQLException {
	throw new SQLException("not supported");
    }

    public void setDate(String parameterName, java.sql.Date val)
	throws SQLException {
	throw new SQLException("not supported");
    }

    public void setTime(String parameterName, java.sql.Time val)
	throws SQLException {
	throw new SQLException("not supported");
    }

    public void setTimestamp(String parameterName, java.sql.Timestamp val)
	throws SQLException {
	throw new SQLException("not supported");
    }

    public void setAsciiStream(String parameterName,
			       java.io.InputStream s, int length)
	throws SQLException {
	throw new SQLException("not supported");
    }

    public void setBinaryStream(String parameterName,
				java.io.InputStream s, int length)
	throws SQLException {
	throw new SQLException("not supported");
    }

    public void setObject(String parameterName, Object val, int targetSqlType,
			  int scale)
	throws SQLException {
	throw new SQLException("not supported");
    }

    public void setObject(String parameterName, Object val, int targetSqlType)
	throws SQLException {
	throw new SQLException("not supported");
    }

    public void setObject(String parameterName, Object val)
	throws SQLException {
	throw new SQLException("not supported");
    }

    public void setCharacterStream(String parameterName,
				   java.io.Reader r, int length)
	throws SQLException {
	throw new SQLException("not supported");
    }

    public void setDate(String parameterName, java.sql.Date val,
			Calendar cal)
	throws SQLException {
	throw new SQLException("not supported");
    }

    public void setTime(String parameterName, java.sql.Time val,
			Calendar cal)
	throws SQLException {
	throw new SQLException("not supported");
    }

    public void setTimestamp(String parameterName, java.sql.Timestamp val,
			     Calendar cal)
	throws SQLException {
	throw new SQLException("not supported");
    }

    public void setNull(String parameterName, int sqlType, String typeName)
	throws SQLException {
	throw new SQLException("not supported");
    }

    public String getString(String parameterName) throws SQLException {
	throw new SQLException("not supported");
    }

    public boolean getBoolean(String parameterName) throws SQLException {
	throw new SQLException("not supported");
    }

    public byte getByte(String parameterName) throws SQLException {
	throw new SQLException("not supported");
    }

    public short getShort(String parameterName) throws SQLException {
	throw new SQLException("not supported");
    }

    public int getInt(String parameterName) throws SQLException {
	throw new SQLException("not supported");
    }

    public long getLong(String parameterName) throws SQLException {
	throw new SQLException("not supported");
    }

    public float getFloat(String parameterName) throws SQLException {
	throw new SQLException("not supported");
    }

    public double getDouble(String parameterName) throws SQLException {
	throw new SQLException("not supported");
    }

    public byte[] getBytes(String parameterName) throws SQLException {
	throw new SQLException("not supported");
    }

    public java.sql.Date getDate(String parameterName) throws SQLException {
	throw new SQLException("not supported");
    }

    public java.sql.Time getTime(String parameterName) throws SQLException {
	throw new SQLException("not supported");
    }

    public java.sql.Timestamp getTimestamp(String parameterName)
	throws SQLException {
	throw new SQLException("not supported");
    }

    public Object getObject(String parameterName) throws SQLException {
	throw new SQLException("not supported");
    }

    public Object getObject(int parameterIndex) throws SQLException {
	throw new SQLException("not supported");
    }

    public BigDecimal getBigDecimal(String parameterName) throws SQLException {
	throw new SQLException("not supported");
    }

    public Object getObject(String parameterName, Map map)
	throws SQLException {
	throw new SQLException("not supported");
    }

    public Object getObject(int parameterIndex, Map map)
	throws SQLException {
	throw new SQLException("not supported");
    }

    public Ref getRef(int parameterIndex) throws SQLException {
	throw new SQLException("not supported");
    }

    public Ref getRef(String parameterName) throws SQLException {
	throw new SQLException("not supported");
    }

    public Blob getBlob(String parameterName) throws SQLException {
	throw new SQLException("not supported");
    }

    public Blob getBlob(int parameterIndex) throws SQLException {
	throw new SQLException("not supported");
    }

    public Clob getClob(String parameterName) throws SQLException {
	throw new SQLException("not supported");
    }

    public Clob getClob(int parameterIndex) throws SQLException {
	throw new SQLException("not supported");
    }

    public Array getArray(String parameterName) throws SQLException {
	throw new SQLException("not supported");
    }

    public Array getArray(int parameterIndex) throws SQLException {
	throw new SQLException("not supported");
    }

    public java.sql.Date getDate(String parameterName, Calendar cal)
	throws SQLException {
	throw new SQLException("not supported");
    }

    public java.sql.Date getDate(int parameterIndex, Calendar cal)
	throws SQLException {
	throw new SQLException("not supported");
    }

    public java.sql.Time getTime(String parameterName, Calendar cal)
	throws SQLException {
	throw new SQLException("not supported");
    }

    public java.sql.Time getTime(int parameterIndex, Calendar cal)
	throws SQLException {
	throw new SQLException("not supported");
    }

    public java.sql.Timestamp getTimestamp(String parameterName, Calendar cal)
	throws SQLException {
	throw new SQLException("not supported");
    }

    public java.sql.Timestamp getTimestamp(int parameterIndex, Calendar cal)
	throws SQLException {
	throw new SQLException("not supported");
    }

    public java.net.URL getURL(String parameterName) throws SQLException {
	throw new SQLException("not supported");
    }

    public void setRowId(int parameterIndex, RowId x) throws SQLException {
	throw new SQLFeatureNotSupportedException();
    }

    public void setRowId(String parameterName, RowId x) throws SQLException {
	throw new SQLFeatureNotSupportedException();
    }

    public void setNString(int parameterIndex, String value)
	throws SQLException {
	throw new SQLFeatureNotSupportedException();
    }

    public void setNString(String parameterName, String value)
	throws SQLException {
	throw new SQLFeatureNotSupportedException();
    }

    public void setNCharacterStream(int parameterIndex, java.io.Reader x,
				    long len)
	throws SQLException {
	throw new SQLFeatureNotSupportedException();
    }

    public void setNCharacterStream(String parameterName, java.io.Reader x,
				    long len)
	throws SQLException {
	throw new SQLFeatureNotSupportedException();
    }

    public void setNClob(int parameterIndex, NClob value)
	throws SQLException {
	throw new SQLFeatureNotSupportedException();
    }

    public void setNClob(String parameterName, NClob value)
	throws SQLException {
	throw new SQLFeatureNotSupportedException();
    }

    public void setClob(int parameterIndex, java.io.Reader x, long len)
	throws SQLException {
	throw new SQLFeatureNotSupportedException();
    }

    public void setClob(String parameterName, java.io.Reader x, long len)
	throws SQLException {
	throw new SQLFeatureNotSupportedException();
    }

    public void setBlob(int parameterIndex, java.io.InputStream x, long len)
	throws SQLException {
	throw new SQLFeatureNotSupportedException();
    }

    public void setBlob(String parameterName, java.io.InputStream x, long len)
	throws SQLException {
	throw new SQLFeatureNotSupportedException();
    }

    public void setNClob(int parameterIndex, java.io.Reader x, long len)
	throws SQLException {
	throw new SQLFeatureNotSupportedException();
    }

    public void setNClob(String parameterName, java.io.Reader x, long len)
	throws SQLException {
	throw new SQLFeatureNotSupportedException();
    }

    public void setSQLXML(int parameterIndex, SQLXML xml)
	throws SQLException {
	throw new SQLFeatureNotSupportedException();
    }

    public void setSQLXML(String parameterName, SQLXML xml)
	throws SQLException {
	throw new SQLFeatureNotSupportedException();
    }

    public void setAsciiStream(int parameterIndex, java.io.InputStream x,
			       long len)
	throws SQLException {
	throw new SQLFeatureNotSupportedException();
    }

    public void setAsciiStream(String parameterName, java.io.InputStream x,
			       long len)
	throws SQLException {
	throw new SQLFeatureNotSupportedException();
    }

    public void setBinaryStream(int parameterIndex, java.io.InputStream x,
				long len)
	throws SQLException {
	throw new SQLFeatureNotSupportedException();
    }

    public void setBinaryStream(String parameterName, java.io.InputStream x,
				long len)
	throws SQLException {
	throw new SQLFeatureNotSupportedException();
    }

    public void setCharacterStream(int parameterIndex, java.io.Reader x,
				   long len)
	throws SQLException {
	throw new SQLFeatureNotSupportedException();
    }

    public void setCharacterStream(String parameterName, java.io.Reader x,
				   long len)
	throws SQLException {
	throw new SQLFeatureNotSupportedException();
    }

    public void setAsciiStream(int parameterIndex, java.io.InputStream x)
	throws SQLException {
	throw new SQLFeatureNotSupportedException();
    }

    public void setAsciiStream(String parameterName, java.io.InputStream x)
	throws SQLException {
	throw new SQLFeatureNotSupportedException();
    }

    public void setBinaryStream(int parameterIndex, java.io.InputStream x)
	throws SQLException {
	throw new SQLFeatureNotSupportedException();
    }

    public void setBinaryStream(String parameterName, java.io.InputStream x)
	throws SQLException {
	throw new SQLFeatureNotSupportedException();
    }

    public void setCharacterStream(int parameterIndex, java.io.Reader x)
	throws SQLException {
	throw new SQLFeatureNotSupportedException();
    }

    public void setCharacterStream(String parameterName, java.io.Reader x)
	throws SQLException {
	throw new SQLFeatureNotSupportedException();
    }

    public void setNCharacterStream(int parameterIndex, java.io.Reader x)
	throws SQLException {
	throw new SQLFeatureNotSupportedException();
    }

    public void setNCharacterStream(String parameterName, java.io.Reader x)
	throws SQLException {
	throw new SQLFeatureNotSupportedException();
    }

    public void setClob(int parameterIndex, java.io.Reader x)
	throws SQLException {
	throw new SQLFeatureNotSupportedException();
    }

    public void setClob(String parameterName, java.io.Reader x)
	throws SQLException {
	throw new SQLFeatureNotSupportedException();
    }

    public void setBlob(int parameterIndex, java.io.InputStream x)
	throws SQLException {
	throw new SQLFeatureNotSupportedException();
    }

    public void setBlob(String parameterName, java.io.InputStream x)
	throws SQLException {
	throw new SQLFeatureNotSupportedException();
    }

    public void setNClob(int parameterIndex, java.io.Reader x)
	throws SQLException {
	throw new SQLFeatureNotSupportedException();
    }

    public void setNClob(String parameterName, java.io.Reader x)
	throws SQLException {
	throw new SQLFeatureNotSupportedException();
    }

}