Java 带有Statement.RETURN\u生成的\u键的PreparedStatement

Java 带有Statement.RETURN\u生成的\u键的PreparedStatement,java,jdbc,Java,Jdbc,某些JDBC驱动程序返回语句的唯一方法是执行以下操作: 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())

某些JDBC驱动程序返回
语句的唯一方法是执行以下操作:

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
执行相同的操作


编辑

我之所以问我是否可以用<代码> PravaRealds< /C>做同样的事情,请考虑下面的场景:

private static final String SQL_CREATE = 
            "INSERT INTO
            USER(FIRST_NAME, MIDDLE_NAME, LAST_NAME, EMAIL_ADDRESS, DOB) 
            VALUES (?, ?, ?, ?, ?)";
USER
表中有一个
主键(USER\u ID)
,它是一个
BIGINT AUTOINCREMENT
(因此为什么在
SQL\u CREATE
字符串中看不到它)


现在,我使用
PreparedStatement.setXXXX(index,value)
填充
。我想返回
ResultSet rs=PreparedStatement.getGeneratedKeys()
。如何实现这一点?

我现在没有编译器,我将通过问一个问题来回答:

你试过这个吗?有用吗

long key = -1L;
PreparedStatement statement = connection.prepareStatement();
statement.executeUpdate(YOUR_SQL_HERE, PreparedStatement.RETURN_GENERATED_KEYS);
ResultSet rs = statement.getGeneratedKeys();
if (rs != null && rs.next()) {
    key = rs.getLong(1);
}
免责声明:显然,我还没有编译这个,但你明白了


是的子接口,因此我看不出这不起作用的原因,除非某些JDBC驱动程序有缺陷。

您可以使用
prepareStatement
方法,并附加
int
参数

PreparedStatement ps = con.prepareStatement(sql, Statement.RETURN_GENERATED_KEYS)
对于某些JDBC驱动程序(例如Oracle),必须显式列出生成键的列名或索引:

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

你是说像这样的

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);
}

这不是我想要的,我知道
PreparedStatement
Statement
的一个子类。请看我的最新帖子。我已经接受了你的答案,因为你已经展示了更多实现相同结果的方法。你不应该在finally块中释放连接,而不是在finally块之外吗(如果您遇到任何类型的运行时异常,您都会失去连接)@niraj-我们可以编写Statement.RETURN\u GENERATED\u key,而不是ps.RETURN\u GENERATED\u key,因为它是java.sql.Statement类中的静态变量。许多人误解并使用了PreparedStatement\executeUpdate(arg).Java doc说,
不能在PreparedStatement或CallableStatement上调用此带参数的方法。
这意味着即使
executeUpdate(arg)不带参数,也必须使用executeUpdate()
方法可以在PreparedStatement类中继承,但我们不必使用它,否则我们将得到SQLException。生成的键结果集怎么可能为null?如果生成了键,则键否则键=0如果未生成
private void alarmEventInsert(DriveDetail driveDetail, String vehicleRegNo, int organizationId) {

    final String ALARM_EVENT_INS_SQL = "INSERT INTO alarm_event (event_code,param1,param2,org_id,created_time) VALUES (?,?,?,?,?)";
    CachedConnection conn = JDatabaseManager.getConnection();
    PreparedStatement ps = null;
    ResultSet generatedKeys = null;
    try {
        ps = conn.prepareStatement(ALARM_EVENT_INS_SQL, ps.RETURN_GENERATED_KEYS);
        ps.setInt(1, driveDetail.getEventCode());
        ps.setString(2, vehicleRegNo);
        ps.setString(3, null);
        ps.setInt(4, organizationId);
        ps.setString(5, driveDetail.getCreateTime());
        ps.execute();
        generatedKeys = ps.getGeneratedKeys();
        if (generatedKeys.next()) {
            driveDetail.setStopDuration(generatedKeys.getInt(1));
        }
    } catch (SQLException e) {
        e.printStackTrace();
        logger.error("Error inserting into alarm_event : {}", e
                .getMessage());
        logger.info(ps.toString());
    } finally {
        if (ps != null) {
            try {

                if (ps != null)
                    ps.close();
            } catch (SQLException e) {
                logger.error("Error closing prepared statements : {}", e
                        .getMessage());
            }
        }
    }
    JDatabaseManager.freeConnection(conn);
}
String query = "INSERT INTO ....";
PreparedStatement preparedStatement = connection.prepareStatement(query, PreparedStatement.RETURN_GENERATED_KEYS);

preparedStatement.setXXX(1, VALUE); 
preparedStatement.setXXX(2, VALUE); 
....
preparedStatement.executeUpdate();  

ResultSet rs = preparedStatement.getGeneratedKeys();  
int key = rs.next() ? rs.getInt(1) : 0;

if(key!=0){
    System.out.println("Generated key="+key);
}