1 package SQLite.JDBC2z;
2 
3 import java.sql.*;
4 import java.math.BigDecimal;
5 import java.util.*;
6 
7 class BatchArg {
8     String arg;
9     boolean blob;
10 
BatchArg(String arg, boolean blob)11     BatchArg(String arg, boolean blob) {
12 	if (arg == null) {
13 	    this.arg = null;
14 	} else {
15 	    this.arg = new String(arg);
16 	}
17 	this.blob = blob;
18     }
19 }
20 
21 public class JDBCPreparedStatement extends JDBCStatement
22     implements java.sql.PreparedStatement {
23 
24     private String sql;
25     private String args[];
26     private boolean blobs[];
27     private ArrayList<BatchArg> batch;
28     private static final boolean nullrepl =
29 	SQLite.Database.version().compareTo("2.5.0") < 0;
30 
31     public JDBCPreparedStatement(JDBCConnection conn, String sql) {
32 	super(conn);
33 	this.args = null;
34 	this.blobs = null;
35 	this.batch = null;
36 	this.sql = fixup(sql);
37     }
38 
39     private String fixup(String sql) {
40 	StringBuffer sb = new StringBuffer();
41 	boolean inq = false;
42 	int nparm = 0;
43 	for (int i = 0; i < sql.length(); i++) {
44 	    char c = sql.charAt(i);
45 	    if (c == '\'') {
46 		if (inq) {
47                     char nextChar = 0;
48                     if(i + 1 < sql.length()) {
49                         nextChar = sql.charAt(i + 1);
50                     }
51 		    if (nextChar == '\'') {
52                         sb.append(c);
53                         sb.append(nextChar);
54                         i++;
55                     } else {
56 			inq = false;
57                         sb.append(c);
58                     }
59 		} else {
60 		    inq = true;
61                     sb.append(c);
62 		}
63 	    } else if (c == '?') {
64 		if (inq) {
65 		    sb.append(c);
66 		} else {
67 		    ++nparm;
68 		    sb.append(nullrepl ? "'%q'" : "%Q");
69 		}
70 	    } else if (c == ';') {
71 		if (!inq) {
72 		    break;
73 		}
74 		sb.append(c);
75 	    } else if (c == '%') {
76 		sb.append("%%");
77 	    } else {
78 		sb.append(c);
79 	    }
80 	}
81 	args = new String[nparm];
82 	blobs = new boolean[nparm];
83 	try {
84 	    clearParameters();
85 	} catch (SQLException e) {
86 	}
87 	return sb.toString();
88     }
89 
90     private String fixup2(String sql) {
91 	if (!conn.db.is3()) {
92 	    return sql;
93 	}
94 	StringBuffer sb = new StringBuffer();
95 	int parm = -1;
96 	for (int i = 0; i < sql.length(); i++) {
97 	    char c = sql.charAt(i);
98 	    if (c == '%') {
99 		sb.append(c);
100 		++i;
101 		c = sql.charAt(i);
102 		if (c == 'Q') {
103 		    parm++;
104 		    if (blobs[parm]) {
105 			c = 's';
106 		    }
107 		}
108 	    }
109 	    sb.append(c);
110 	}
111 	return sb.toString();
112     }
113 
114     public ResultSet executeQuery() throws SQLException {
115 	return executeQuery(fixup2(sql), args, false);
116     }
117 
118     public int executeUpdate() throws SQLException {
119 	executeQuery(fixup2(sql), args, true);
120 	return updcnt;
121     }
122 
123     public void setNull(int parameterIndex, int sqlType) throws SQLException {
124 	if (parameterIndex < 1 || parameterIndex > args.length) {
125 	    throw new SQLException("bad parameter index");
126 	}
127 	args[parameterIndex - 1] = nullrepl ? "" : null;
128 	blobs[parameterIndex - 1] = false;
129     }
130 
131     public void setBoolean(int parameterIndex, boolean x)
132 	throws SQLException {
133 	if (parameterIndex < 1 || parameterIndex > args.length) {
134 	    throw new SQLException("bad parameter index");
135 	}
136 	args[parameterIndex - 1] = x ? "1" : "0";
137 	blobs[parameterIndex - 1] = false;
138     }
139 
140     public void setByte(int parameterIndex, byte x) throws SQLException {
141 	if (parameterIndex < 1 || parameterIndex > args.length) {
142 	    throw new SQLException("bad parameter index");
143 	}
144 	args[parameterIndex - 1] = "" + x;
145 	blobs[parameterIndex - 1] = false;
146     }
147 
148     public void setShort(int parameterIndex, short x) throws SQLException {
149 	if (parameterIndex < 1 || parameterIndex > args.length) {
150 	    throw new SQLException("bad parameter index");
151 	}
152 	args[parameterIndex - 1] = "" + x;
153 	blobs[parameterIndex - 1] = false;
154     }
155 
156     public void setInt(int parameterIndex, int x) throws SQLException {
157 	if (parameterIndex < 1 || parameterIndex > args.length) {
158 	    throw new SQLException("bad parameter index");
159 	}
160 	args[parameterIndex - 1] = "" + x;
161 	blobs[parameterIndex - 1] = false;
162     }
163 
164     public void setLong(int parameterIndex, long x) throws SQLException {
165 	if (parameterIndex < 1 || parameterIndex > args.length) {
166 	    throw new SQLException("bad parameter index");
167 	}
168 	args[parameterIndex - 1] = "" + x;
169 	blobs[parameterIndex - 1] = false;
170     }
171 
172     public void setFloat(int parameterIndex, float x) throws SQLException {
173 	if (parameterIndex < 1 || parameterIndex > args.length) {
174 	    throw new SQLException("bad parameter index");
175 	}
176 	args[parameterIndex - 1] = "" + x;
177 	blobs[parameterIndex - 1] = false;
178     }
179 
180     public void setDouble(int parameterIndex, double x) throws SQLException {
181 	if (parameterIndex < 1 || parameterIndex > args.length) {
182 	    throw new SQLException("bad parameter index");
183 	}
184 	args[parameterIndex - 1] = "" + x;
185 	blobs[parameterIndex - 1] = false;
186     }
187 
188     public void setBigDecimal(int parameterIndex, BigDecimal x)
189 	throws SQLException {
190 	if (parameterIndex < 1 || parameterIndex > args.length) {
191 	    throw new SQLException("bad parameter index");
192 	}
193 	if (x == null) {
194 	    args[parameterIndex - 1] = nullrepl ? "" : null;
195 	} else {
196 	    args[parameterIndex - 1] = "" + x;
197 	}
198 	blobs[parameterIndex - 1] = false;
199     }
200 
201     public void setString(int parameterIndex, String x) throws SQLException {
202 	if (parameterIndex < 1 || parameterIndex > args.length) {
203 	    throw new SQLException("bad parameter index");
204 	}
205 	if (x == null) {
206 	    args[parameterIndex - 1] = nullrepl ? "" : null;
207 	} else {
208 	    args[parameterIndex - 1] = x;
209 	}
210 	blobs[parameterIndex - 1] = false;
211     }
212 
213     public void setBytes(int parameterIndex, byte x[]) throws SQLException {
214 	if (parameterIndex < 1 || parameterIndex > args.length) {
215 	    throw new SQLException("bad parameter index");
216 	}
217 	blobs[parameterIndex - 1] = false;
218 	if (x == null) {
219 	    args[parameterIndex - 1] = nullrepl ? "" : null;
220 	} else {
221 	    if (conn.db.is3()) {
222 		args[parameterIndex - 1] = SQLite.StringEncoder.encodeX(x);
223 		blobs[parameterIndex - 1] = true;
224 	    } else {
225 		args[parameterIndex - 1] = SQLite.StringEncoder.encode(x);
226 	    }
227 	}
228     }
229 
230     public void setDate(int parameterIndex, java.sql.Date x)
231 	throws SQLException {
232 	if (parameterIndex < 1 || parameterIndex > args.length) {
233 	    throw new SQLException("bad parameter index");
234 	}
235 	if (x == null) {
236 	    args[parameterIndex - 1] = nullrepl ? "" : null;
237 	} else {
238 	    if (conn.useJulian) {
239 		args[parameterIndex - 1] = java.lang.Double.toString(SQLite.Database.julian_from_long(x.getTime()));
240 	    } else {
241 		args[parameterIndex - 1] = x.toString();
242 	    }
243 	}
244 	blobs[parameterIndex - 1] = false;
245     }
246 
247     public void setTime(int parameterIndex, java.sql.Time x)
248 	throws SQLException {
249 	if (parameterIndex < 1 || parameterIndex > args.length) {
250 	    throw new SQLException("bad parameter index");
251 	}
252 	if (x == null) {
253 	    args[parameterIndex - 1] = nullrepl ? "" : null;
254 	} else {
255 	    if (conn.useJulian) {
256 		args[parameterIndex - 1] = java.lang.Double.toString(SQLite.Database.julian_from_long(x.getTime()));
257 	    } else {
258 		args[parameterIndex - 1] = x.toString();
259 	    }
260 	}
261 	blobs[parameterIndex - 1] = false;
262     }
263 
264     public void setTimestamp(int parameterIndex, java.sql.Timestamp x)
265 	throws SQLException {
266 	if (parameterIndex < 1 || parameterIndex > args.length) {
267 	    throw new SQLException("bad parameter index");
268 	}
269 	if (x == null) {
270 	    args[parameterIndex - 1] = nullrepl ? "" : null;
271 	} else {
272 	    if (conn.useJulian) {
273 		args[parameterIndex - 1] = java.lang.Double.toString(SQLite.Database.julian_from_long(x.getTime()));
274 	    } else {
275 		args[parameterIndex - 1] = x.toString();
276 	    }
277 	}
278 	blobs[parameterIndex - 1] = false;
279     }
280 
281     public void setAsciiStream(int parameterIndex, java.io.InputStream x,
282 			       int length) throws SQLException {
283 	throw new SQLException("not supported");
284     }
285 
286     @Deprecated
287     public void setUnicodeStream(int parameterIndex, java.io.InputStream x,
288 				 int length) throws SQLException {
289 	throw new SQLFeatureNotSupportedException();
290     }
291 
292     public void setBinaryStream(int parameterIndex, java.io.InputStream x,
293 				int length) throws SQLException {
294 	try {
295 	    byte[] data = new byte[length];
296 	    x.read(data, 0, length);
297 	    setBytes(parameterIndex, data);
298 	} catch (java.io.IOException e) {
299 	    throw new SQLException("I/O failed");
300 	}
301     }
302 
303     public void clearParameters() throws SQLException {
304 	for (int i = 0; i < args.length; i++) {
305 	    args[i] = nullrepl ? "" : null;
306 	    blobs[i] = false;
307 	}
308     }
309 
310     public void setObject(int parameterIndex, Object x, int targetSqlType,
311 			  int scale) throws SQLException {
312 	if (parameterIndex < 1 || parameterIndex > args.length) {
313 	    throw new SQLException("bad parameter index");
314 	}
315 	if (x == null) {
316 	    args[parameterIndex - 1] = nullrepl ? "" : null;
317 	} else {
318 	    if (x instanceof byte[]) {
319 		byte[] bx = (byte[]) x;
320 		if (conn.db.is3()) {
321 		    args[parameterIndex - 1] =
322 			  SQLite.StringEncoder.encodeX(bx);
323 		    blobs[parameterIndex - 1] = true;
324 		    return;
325 		}
326 		args[parameterIndex - 1] = SQLite.StringEncoder.encode(bx);
327 	    } else {
328 		args[parameterIndex - 1] = x.toString();
329 	    }
330 	}
331 	blobs[parameterIndex - 1] = false;
332     }
333 
334     public void setObject(int parameterIndex, Object x, int targetSqlType)
335 	throws SQLException {
336 	if (parameterIndex < 1 || parameterIndex > args.length) {
337 	    throw new SQLException("bad parameter index");
338 	}
339 	if (x == null) {
340 	    args[parameterIndex - 1] = nullrepl ? "" : null;
341 	} else {
342 	    if (x instanceof byte[]) {
343 		byte[] bx = (byte[]) x;
344 		if (conn.db.is3()) {
345 		    args[parameterIndex - 1] =
346 			SQLite.StringEncoder.encodeX(bx);
347 		    blobs[parameterIndex - 1] = true;
348 		    return;
349 		}
350 		args[parameterIndex - 1] = SQLite.StringEncoder.encode(bx);
351 	    } else {
352 		args[parameterIndex - 1] = x.toString();
353 	    }
354 	}
355 	blobs[parameterIndex - 1] = false;
356     }
357 
358     public void setObject(int parameterIndex, Object x) throws SQLException {
359 	if (parameterIndex < 1 || parameterIndex > args.length) {
360 	    throw new SQLException("bad parameter index");
361 	}
362 	if (x == null) {
363 	    args[parameterIndex - 1] = nullrepl ? "" : null;
364 	} else {
365 	    if (x instanceof byte[]) {
366 		byte[] bx = (byte[]) x;
367 		if (conn.db.is3()) {
368 		    args[parameterIndex - 1] =
369 			SQLite.StringEncoder.encodeX(bx);
370 		    blobs[parameterIndex - 1] = true;
371 		    return;
372 		}
373 		args[parameterIndex - 1] = SQLite.StringEncoder.encode(bx);
374 	    } else {
375 		args[parameterIndex - 1] = x.toString();
376 	    }
377 	}
378 	blobs[parameterIndex - 1] = false;
379     }
380 
381     public boolean execute() throws SQLException {
382 	return executeQuery(fixup2(sql), args, false) != null;
383     }
384 
385     public void addBatch() throws SQLException {
386 	if (batch == null) {
387 	    batch = new ArrayList<BatchArg>(args.length);
388 	}
389 	for (int i = 0; i < args.length; i++) {
390 	    batch.add(new BatchArg(args[i], blobs[i]));
391 	}
392     }
393 
394     public int[] executeBatch() throws SQLException {
395 	if (batch == null) {
396 	    return new int[0];
397 	}
398 	int[] ret = new int[batch.size() / args.length];
399 	for (int i = 0; i < ret.length; i++) {
400 	    ret[i] = EXECUTE_FAILED;
401 	}
402 	int errs = 0;
403 	int index = 0;
404 	for (int i = 0; i < ret.length; i++) {
405 	    for (int k = 0; k < args.length; k++) {
406 		BatchArg b = (BatchArg) batch.get(index++);
407 
408 		args[k] = b.arg;
409 		blobs[k] = b.blob;
410 	    }
411 	    try {
412 		ret[i] = executeUpdate();
413 	    } catch (SQLException e) {
414 		++errs;
415 	    }
416 	}
417 	if (errs > 0) {
418 	    throw new BatchUpdateException("batch failed", ret);
419 	}
420 	return ret;
421     }
422 
423     public void clearBatch() throws SQLException {
424 	if (batch != null) {
425 	    batch.clear();
426 	    batch = null;
427 	}
428     }
429 
430     public void close() throws SQLException {
431     	clearBatch();
432 	super.close();
433     }
434 
435     public void setCharacterStream(int parameterIndex,
436 				   java.io.Reader reader,
437 				   int length) throws SQLException {
438 	try {
439 	    char[] data = new char[length];
440 	    reader.read(data);
441 	    setString(parameterIndex, new String(data));
442 	} catch (java.io.IOException e) {
443 	    throw new SQLException("I/O failed");
444 	}
445     }
446 
447     public void setRef(int i, Ref x) throws SQLException {
448 	throw new SQLFeatureNotSupportedException();
449     }
450 
451     public void setBlob(int i, Blob x) throws SQLException {
452 	throw new SQLFeatureNotSupportedException();
453     }
454 
455     public void setClob(int i, Clob x) throws SQLException {
456 	throw new SQLFeatureNotSupportedException();
457     }
458 
459     public void setArray(int i, Array x) throws SQLException {
460 	throw new SQLFeatureNotSupportedException();
461     }
462 
463     public ResultSetMetaData getMetaData() throws SQLException {
464 	return rs.getMetaData();
465     }
466 
467     public void setDate(int parameterIndex, java.sql.Date x, Calendar cal)
468 	throws SQLException {
469 	setDate(parameterIndex, x);
470     }
471 
472     public void setTime(int parameterIndex, java.sql.Time x, Calendar cal)
473 	throws SQLException {
474 	setTime(parameterIndex, x);
475     }
476 
477     public void setTimestamp(int parameterIndex, java.sql.Timestamp x,
478 			     Calendar cal) throws SQLException {
479 	setTimestamp(parameterIndex, x);
480     }
481 
482     public void setNull(int parameterIndex, int sqlType, String typeName)
483 	throws SQLException {
484 	setNull(parameterIndex, sqlType);
485     }
486 
487     public ParameterMetaData getParameterMetaData() throws SQLException {
488 	throw new SQLException("not supported");
489     }
490 
491     public void registerOutputParameter(String parameterName, int sqlType)
492 	throws SQLException {
493 	throw new SQLException("not supported");
494     }
495 
496     public void registerOutputParameter(String parameterName, int sqlType,
497 					int scale)
498 	throws SQLException {
499 	throw new SQLException("not supported");
500     }
501 
502     public void registerOutputParameter(String parameterName, int sqlType,
503 					String typeName)
504 	throws SQLException {
505 	throw new SQLException("not supported");
506     }
507 
508     public java.net.URL getURL(int parameterIndex) throws SQLException {
509 	throw new SQLException("not supported");
510     }
511 
512     public void setURL(int parameterIndex, java.net.URL url)
513 	throws SQLException {
514 	throw new SQLException("not supported");
515     }
516 
517     public void setNull(String parameterName, int sqlType)
518 	throws SQLException {
519 	throw new SQLException("not supported");
520     }
521 
522     public void setBoolean(String parameterName, boolean val)
523 	throws SQLException {
524 	throw new SQLException("not supported");
525     }
526 
527     public void setByte(String parameterName, byte val)
528 	throws SQLException {
529 	throw new SQLException("not supported");
530     }
531 
532     public void setShort(String parameterName, short val)
533 	throws SQLException {
534 	throw new SQLException("not supported");
535     }
536 
537     public void setInt(String parameterName, int val)
538 	throws SQLException {
539 	throw new SQLException("not supported");
540     }
541 
542     public void setLong(String parameterName, long val)
543 	throws SQLException {
544 	throw new SQLException("not supported");
545     }
546 
547     public void setFloat(String parameterName, float val)
548 	throws SQLException {
549 	throw new SQLException("not supported");
550     }
551 
552     public void setDouble(String parameterName, double val)
553 	throws SQLException {
554 	throw new SQLException("not supported");
555     }
556 
557     public void setBigDecimal(String parameterName, BigDecimal val)
558 	throws SQLException {
559 	throw new SQLException("not supported");
560     }
561 
562     public void setString(String parameterName, String val)
563 	throws SQLException {
564 	throw new SQLException("not supported");
565     }
566 
567     public void setBytes(String parameterName, byte val[])
568 	throws SQLException {
569 	throw new SQLException("not supported");
570     }
571 
572     public void setDate(String parameterName, java.sql.Date val)
573 	throws SQLException {
574 	throw new SQLException("not supported");
575     }
576 
577     public void setTime(String parameterName, java.sql.Time val)
578 	throws SQLException {
579 	throw new SQLException("not supported");
580     }
581 
582     public void setTimestamp(String parameterName, java.sql.Timestamp val)
583 	throws SQLException {
584 	throw new SQLException("not supported");
585     }
586 
587     public void setAsciiStream(String parameterName,
588 			       java.io.InputStream s, int length)
589 	throws SQLException {
590 	throw new SQLException("not supported");
591     }
592 
593     public void setBinaryStream(String parameterName,
594 				java.io.InputStream s, int length)
595 	throws SQLException {
596 	throw new SQLException("not supported");
597     }
598 
599     public void setObject(String parameterName, Object val, int targetSqlType,
600 			  int scale)
601 	throws SQLException {
602 	throw new SQLException("not supported");
603     }
604 
605     public void setObject(String parameterName, Object val, int targetSqlType)
606 	throws SQLException {
607 	throw new SQLException("not supported");
608     }
609 
610     public void setObject(String parameterName, Object val)
611 	throws SQLException {
612 	throw new SQLException("not supported");
613     }
614 
615     public void setCharacterStream(String parameterName,
616 				   java.io.Reader r, int length)
617 	throws SQLException {
618 	throw new SQLException("not supported");
619     }
620 
621     public void setDate(String parameterName, java.sql.Date val,
622 			Calendar cal)
623 	throws SQLException {
624 	throw new SQLException("not supported");
625     }
626 
627     public void setTime(String parameterName, java.sql.Time val,
628 			Calendar cal)
629 	throws SQLException {
630 	throw new SQLException("not supported");
631     }
632 
633     public void setTimestamp(String parameterName, java.sql.Timestamp val,
634 			     Calendar cal)
635 	throws SQLException {
636 	throw new SQLException("not supported");
637     }
638 
639     public void setNull(String parameterName, int sqlType, String typeName)
640 	throws SQLException {
641 	throw new SQLException("not supported");
642     }
643 
644     public String getString(String parameterName) throws SQLException {
645 	throw new SQLException("not supported");
646     }
647 
648     public boolean getBoolean(String parameterName) throws SQLException {
649 	throw new SQLException("not supported");
650     }
651 
652     public byte getByte(String parameterName) throws SQLException {
653 	throw new SQLException("not supported");
654     }
655 
656     public short getShort(String parameterName) throws SQLException {
657 	throw new SQLException("not supported");
658     }
659 
660     public int getInt(String parameterName) throws SQLException {
661 	throw new SQLException("not supported");
662     }
663 
664     public long getLong(String parameterName) throws SQLException {
665 	throw new SQLException("not supported");
666     }
667 
668     public float getFloat(String parameterName) throws SQLException {
669 	throw new SQLException("not supported");
670     }
671 
672     public double getDouble(String parameterName) throws SQLException {
673 	throw new SQLException("not supported");
674     }
675 
676     public byte[] getBytes(String parameterName) throws SQLException {
677 	throw new SQLException("not supported");
678     }
679 
680     public java.sql.Date getDate(String parameterName) throws SQLException {
681 	throw new SQLException("not supported");
682     }
683 
684     public java.sql.Time getTime(String parameterName) throws SQLException {
685 	throw new SQLException("not supported");
686     }
687 
688     public java.sql.Timestamp getTimestamp(String parameterName)
689 	throws SQLException {
690 	throw new SQLException("not supported");
691     }
692 
693     public Object getObject(String parameterName) throws SQLException {
694 	throw new SQLException("not supported");
695     }
696 
697     public Object getObject(int parameterIndex) throws SQLException {
698 	throw new SQLException("not supported");
699     }
700 
701     public BigDecimal getBigDecimal(String parameterName) throws SQLException {
702 	throw new SQLException("not supported");
703     }
704 
705     public Object getObject(String parameterName, Map map)
706 	throws SQLException {
707 	throw new SQLException("not supported");
708     }
709 
710     public Object getObject(int parameterIndex, Map map)
711 	throws SQLException {
712 	throw new SQLException("not supported");
713     }
714 
715     public Ref getRef(int parameterIndex) throws SQLException {
716 	throw new SQLException("not supported");
717     }
718 
719     public Ref getRef(String parameterName) throws SQLException {
720 	throw new SQLException("not supported");
721     }
722 
723     public Blob getBlob(String parameterName) throws SQLException {
724 	throw new SQLException("not supported");
725     }
726 
727     public Blob getBlob(int parameterIndex) throws SQLException {
728 	throw new SQLException("not supported");
729     }
730 
731     public Clob getClob(String parameterName) throws SQLException {
732 	throw new SQLException("not supported");
733     }
734 
735     public Clob getClob(int parameterIndex) throws SQLException {
736 	throw new SQLException("not supported");
737     }
738 
739     public Array getArray(String parameterName) throws SQLException {
740 	throw new SQLException("not supported");
741     }
742 
743     public Array getArray(int parameterIndex) throws SQLException {
744 	throw new SQLException("not supported");
745     }
746 
747     public java.sql.Date getDate(String parameterName, Calendar cal)
748 	throws SQLException {
749 	throw new SQLException("not supported");
750     }
751 
752     public java.sql.Date getDate(int parameterIndex, Calendar cal)
753 	throws SQLException {
754 	throw new SQLException("not supported");
755     }
756 
757     public java.sql.Time getTime(String parameterName, Calendar cal)
758 	throws SQLException {
759 	throw new SQLException("not supported");
760     }
761 
762     public java.sql.Time getTime(int parameterIndex, Calendar cal)
763 	throws SQLException {
764 	throw new SQLException("not supported");
765     }
766 
767     public java.sql.Timestamp getTimestamp(String parameterName, Calendar cal)
768 	throws SQLException {
769 	throw new SQLException("not supported");
770     }
771 
772     public java.sql.Timestamp getTimestamp(int parameterIndex, Calendar cal)
773 	throws SQLException {
774 	throw new SQLException("not supported");
775     }
776 
777     public java.net.URL getURL(String parameterName) throws SQLException {
778 	throw new SQLException("not supported");
779     }
780 
781     public void setRowId(int parameterIndex, RowId x) throws SQLException {
782 	throw new SQLFeatureNotSupportedException();
783     }
784 
785     public void setRowId(String parameterName, RowId x) throws SQLException {
786 	throw new SQLFeatureNotSupportedException();
787     }
788 
789     public void setNString(int parameterIndex, String value)
790 	throws SQLException {
791 	throw new SQLFeatureNotSupportedException();
792     }
793 
794     public void setNString(String parameterName, String value)
795 	throws SQLException {
796 	throw new SQLFeatureNotSupportedException();
797     }
798 
799     public void setNCharacterStream(int parameterIndex, java.io.Reader x,
800 				    long len)
801 	throws SQLException {
802 	throw new SQLFeatureNotSupportedException();
803     }
804 
805     public void setNCharacterStream(String parameterName, java.io.Reader x,
806 				    long len)
807 	throws SQLException {
808 	throw new SQLFeatureNotSupportedException();
809     }
810 
811     public void setNClob(int parameterIndex, NClob value)
812 	throws SQLException {
813 	throw new SQLFeatureNotSupportedException();
814     }
815 
816     public void setNClob(String parameterName, NClob value)
817 	throws SQLException {
818 	throw new SQLFeatureNotSupportedException();
819     }
820 
821     public void setClob(int parameterIndex, java.io.Reader x, long len)
822 	throws SQLException {
823 	throw new SQLFeatureNotSupportedException();
824     }
825 
826     public void setClob(String parameterName, java.io.Reader x, long len)
827 	throws SQLException {
828 	throw new SQLFeatureNotSupportedException();
829     }
830 
831     public void setBlob(int parameterIndex, java.io.InputStream x, long len)
832 	throws SQLException {
833 	throw new SQLFeatureNotSupportedException();
834     }
835 
836     public void setBlob(String parameterName, java.io.InputStream x, long len)
837 	throws SQLException {
838 	throw new SQLFeatureNotSupportedException();
839     }
840 
841     public void setNClob(int parameterIndex, java.io.Reader x, long len)
842 	throws SQLException {
843 	throw new SQLFeatureNotSupportedException();
844     }
845 
846     public void setNClob(String parameterName, java.io.Reader x, long len)
847 	throws SQLException {
848 	throw new SQLFeatureNotSupportedException();
849     }
850 
851     public void setSQLXML(int parameterIndex, SQLXML xml)
852 	throws SQLException {
853 	throw new SQLFeatureNotSupportedException();
854     }
855 
856     public void setSQLXML(String parameterName, SQLXML xml)
857 	throws SQLException {
858 	throw new SQLFeatureNotSupportedException();
859     }
860 
861     public void setAsciiStream(int parameterIndex, java.io.InputStream x,
862 			       long len)
863 	throws SQLException {
864 	throw new SQLFeatureNotSupportedException();
865     }
866 
867     public void setAsciiStream(String parameterName, java.io.InputStream x,
868 			       long len)
869 	throws SQLException {
870 	throw new SQLFeatureNotSupportedException();
871     }
872 
873     public void setBinaryStream(int parameterIndex, java.io.InputStream x,
874 				long len)
875 	throws SQLException {
876 	throw new SQLFeatureNotSupportedException();
877     }
878 
879     public void setBinaryStream(String parameterName, java.io.InputStream x,
880 				long len)
881 	throws SQLException {
882 	throw new SQLFeatureNotSupportedException();
883     }
884 
885     public void setCharacterStream(int parameterIndex, java.io.Reader x,
886 				   long len)
887 	throws SQLException {
888 	throw new SQLFeatureNotSupportedException();
889     }
890 
891     public void setCharacterStream(String parameterName, java.io.Reader x,
892 				   long len)
893 	throws SQLException {
894 	throw new SQLFeatureNotSupportedException();
895     }
896 
897     public void setAsciiStream(int parameterIndex, java.io.InputStream x)
898 	throws SQLException {
899 	throw new SQLFeatureNotSupportedException();
900     }
901 
902     public void setAsciiStream(String parameterName, java.io.InputStream x)
903 	throws SQLException {
904 	throw new SQLFeatureNotSupportedException();
905     }
906 
907     public void setBinaryStream(int parameterIndex, java.io.InputStream x)
908 	throws SQLException {
909 	throw new SQLFeatureNotSupportedException();
910     }
911 
912     public void setBinaryStream(String parameterName, java.io.InputStream x)
913 	throws SQLException {
914 	throw new SQLFeatureNotSupportedException();
915     }
916 
917     public void setCharacterStream(int parameterIndex, java.io.Reader x)
918 	throws SQLException {
919 	throw new SQLFeatureNotSupportedException();
920     }
921 
922     public void setCharacterStream(String parameterName, java.io.Reader x)
923 	throws SQLException {
924 	throw new SQLFeatureNotSupportedException();
925     }
926 
927     public void setNCharacterStream(int parameterIndex, java.io.Reader x)
928 	throws SQLException {
929 	throw new SQLFeatureNotSupportedException();
930     }
931 
932     public void setNCharacterStream(String parameterName, java.io.Reader x)
933 	throws SQLException {
934 	throw new SQLFeatureNotSupportedException();
935     }
936 
937     public void setClob(int parameterIndex, java.io.Reader x)
938 	throws SQLException {
939 	throw new SQLFeatureNotSupportedException();
940     }
941 
942     public void setClob(String parameterName, java.io.Reader x)
943 	throws SQLException {
944 	throw new SQLFeatureNotSupportedException();
945     }
946 
947     public void setBlob(int parameterIndex, java.io.InputStream x)
948 	throws SQLException {
949 	throw new SQLFeatureNotSupportedException();
950     }
951 
952     public void setBlob(String parameterName, java.io.InputStream x)
953 	throws SQLException {
954 	throw new SQLFeatureNotSupportedException();
955     }
956 
957     public void setNClob(int parameterIndex, java.io.Reader x)
958 	throws SQLException {
959 	throw new SQLFeatureNotSupportedException();
960     }
961 
962     public void setNClob(String parameterName, java.io.Reader x)
963 	throws SQLException {
964 	throw new SQLFeatureNotSupportedException();
965     }
966 
967 }
968