准备与Statement.RETURN_GENERATED_KEYS

2022-08-31 11:56:59

某些 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 (?, ?, ?, ?, ?)";

在表中有一个 is a (因此,为什么您在字符串中看不到它。USERPRIMARY KEY (USER_ID)BIGINT AUTOINCREMENTSQL_CREATE

现在,我填充了使用.我想回来。我怎样才能做到这一点??PreparedStatement.setXXXX(index, value)ResultSet rs = PreparedStatement.getGeneratedKeys()


答案 1

您可以使用采用附加参数的方法prepareStatementint

PreparedStatement ps = con.prepareStatement(sql, Statement.RETURN_GENERATED_KEYS)

对于某些 JDBC 驱动程序(例如 Oracle),您必须显式列出生成的键的列名或索引:

PreparedStatement ps = con.prepareStatement(sql, new String[]{"USER_ID"})

答案 2

你是说这样的事情吗?

long key = -1L;

PreparedStatement preparedStatement = connection.prepareStatement(YOUR_SQL_HERE, PreparedStatement.RETURN_GENERATED_KEYS);
preparedStatement.setXXX(index, VALUE);
preparedStatement.executeUpdate();

ResultSet rs = preparedStatement.getGeneratedKeys();

if (rs.next()) {
    key = rs.getLong(1);
}

推荐