Я думаю, проблема в том, что ваш тип данных - CHAR (9), а у "Waterloo" всего 8 символов.
Я предполагаю, что это вернет ожидаемые результаты (LIKE и%). Или добавьте недостающее место.
String sql = "SELECT STUDENT FROM SCHOOL WHERE SCHOOL LIKE ? ";
PreparedStatement prepStmt = conn.prepareStatement(sql);
prepStmt.setString(1, "Waterloo%");
ResultSet rs = prepStmt.executeQuery();
Лучше всего использовать varchar вместо char, если ваши строки имеют гибкую длину. Тогда PreparedStatement будет работать как положено.
Обходным решением будет использование специфического для Oracle метода setFixedCHAR (но лучше, если возможно, изменить тип данных на varchar).
Следующее из Oracle PreparedStatement JavaDoc:
Данные CHAR в базе данных дополняются до ширины столбца. Это приводит к ограничению использования метода setCHAR () для привязки символьных данных к предложению WHERE инструкции SELECT - символьные данные в предложении WHERE также должны быть дополнены шириной столбца, чтобы обеспечить соответствие в операторе SELECT. Это особенно хлопотно, если вы не знаете ширину столбца.
setFixedCHAR () исправляет это. Этот метод выполняет сравнение без дополнения.
Примечания:
- Не забудьте преобразовать подготовленный объект оператора в OraclePreparedStatement, чтобы использовать метод setFixedCHAR ().
- Нет необходимости использовать setFixedCHAR () для оператора INSERT. База данных всегда автоматически дополняет данные до ширины столбца при вставке.
В следующем примере демонстрируется различие между методами setString (), setCHAR () и setFixedCHAR ().
// Schema is : create table my_table (col1 char(10));
// insert into my_table values ('JDBC');
PreparedStatement pstmt = conn.prepareStatement
("select count() from my_table where col1 = ?");
ResultSet rs;
pstmt.setString (1, "JDBC"); // Set the Bind Value
rs = pstmt.executeQuery(); // This does not match any row
// ... do something with rs
CHAR ch = new CHAR("JDBC ", null);
((OraclePreparedStatement)pstmt).setCHAR(1, ch); // Pad it to 10 bytes
rs = pstmt.executeQuery(); // This matches one row
// ... do something with rs
((OraclePreparedStatement)pstmt).setFixedCHAR(1, "JDBC");
rs = pstmt.executeQuery(); // This matches one row
// ... do something with rs