Saya agak terkejut melihat dokumen ini. Memang benar bahwa Anda tidak dapat mengatur array/koleksi seperti berikut (dan ini terlepas dari database / driver JDBC yang digunakan):
String sql = "SELECT col FROM tbl WHERE id IN (?)";
statement = connection.prepareStatement(sql);
statement.setArray(1, arrayOfValues); // Fail.
Tetapi permintaan dalam dokumen yang disebutkan seharusnya berfungsi. Saya dapat mengetahui ini dari pengalaman dengan setidaknya Oracle 10g XE dalam kombinasi dengan ojdbc14.jar
. Saya menduga bahwa baik pembuat dokumen bingung, atau sebenarnya menyangkut versi (lama?) dari driver DB dan/atau JDBC yang berbeda.
Yang berikut ini harus berfungsi terlepas dari driver JDBC yang digunakan (walaupun Anda bergantung pada DB yang digunakan berapa banyak item yang dapat berisi klausa IN, Oracle (ya, sekali lagi) memiliki batas sekitar 1000 item):
private static final String SQL_FIND = "SELECT id, name, value FROM data WHERE id IN (%s)";
public List<Data> find(Set<Long> ids) throws SQLException {
Connection connection = null;
PreparedStatement statement = null;
ResultSet resultSet = null;
List<Data> list = new ArrayList<Data>();
String sql = String.format(SQL_FIND, preparePlaceHolders(ids.size()));
try{
connection = database.getConnection();
statement = connection.prepareStatement(sql);
setValues(statement, ids.toArray());
resultSet = statement.executeQuery();
while (resultSet.next()) {
Data data = new Data();
data.setId(resultSet.getLong("id"));
data.setName(resultSet.getString("name"));
data.setValue(resultSet.getInt("value"));
list.add(data);
}
} finally {
close(connection, statement, resultSet);
}
return list;
}
public static String preparePlaceHolders(int length) {
StringBuilder builder = new StringBuilder();
for (int i = 0; i < length;) {
builder.append("?");
if (++i < length) {
builder.append(",");
}
}
return builder.toString();
}
public static void setValues(PreparedStatement preparedStatement, Object... values) throws SQLException {
for (int i = 0; i < values.length; i++) {
preparedStatement.setObject(i + 1, values[i]);
}
}
Sehubungan dengan TIMESTAMP
pertanyaan, cukup gunakan PreparedStatement#setTimestamp()
.