一些 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
字符串中没有看到它)。
现在,我使用 PreparedStatement.setXXXX(index, value)
填充 ?
。我想返回 ResultSet rs = PreparedStatement.getGeneratedKeys()
。我如何实现这一点?