PreparedStatement с Statement.RETURN_GENERATED_KEYS

Единственный способ, которым некоторые 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.

Теперь я заполняю ? с помощью PreparedStatement.setXXXX(index, value). Я хочу вернуть ResultSet rs = PreparedStatement.getGeneratedKeys(). Как мне этого добиться?

78
задан UserNotFoundException 9 January 2017 в 14:45
поделиться