Единственный способ вернуть некоторые драйверы JDBC Statement.RETURN_GENERATED_KEYS
- это сделать что-то из следующего:
long key = -1L;
Statement statement = connection.createStatement();
statement.executeUpdate(YOUR_SQL_HERE, Statement.RETURN_GENERATED_KEYS);
ResultSet rs = statement.getGeneratedKeys();
if (rs != null && rs.next()) {
key = rs.getLong(1);
}
Есть ли способ сделать то же самое с PreparedStatement
?
редактировать
Причина, по которой я спросил, могу ли я сделать то же самое, PreparedStatement
рассмотрим следующий сценарий:
private static final String SQL_CREATE =
"INSERT INTO
USER(FIRST_NAME, MIDDLE_NAME, LAST_NAME, EMAIL_ADDRESS, DOB)
VALUES (?, ?, ?, ?, ?)";
В USER
таблице есть, PRIMARY KEY (USER_ID)
который является BIGINT AUTOINCREMENT
(поэтому вы не видите его в SQL_CREATE
String.
Теперь я заполняю файл ?
using PreparedStatement.setXXXX(index, value)
. Я хочу вернуться ResultSet rs = PreparedStatement.getGeneratedKeys()
. Как я могу этого добиться?
This method with argument cannot be called on a PreparedStatement or CallableStatement.
это означает, что мы должны использовать executeUpdate () без аргументов, даже еслиexecuteUpdate(arg)
метод может быть унаследован в классе PreparedStatement, но нам не нужно его использовать, иначе мы получим SQLException.