相关疑难解决方法(0)

MySQL和Java - 获取最后插入值的ID(JDBC)

可能重复:
如何在JDBC中获取插入ID?

嗨,我正在使用JDBC通过Java连接数据库.

现在,我做一些插入查询,我需要获取最后插入值的id(所以,在a之后stmt.executeUpdate).

我不需要类似的东西SELECT id FROM table ORDER BY id DESC LIMIT 1,因为我可能会遇到并发问题.

我只需要检索与最后一次插入相关的id(关于我的Statement实例).

我试过这个,但似乎它不适用于JDBC:

public Integer insertQueryGetId(String query) {
    Integer numero=0;
    Integer risultato=-1;
    try {
        Statement stmt = db.createStatement();
        numero = stmt.executeUpdate(query);

        ResultSet rs = stmt.getGeneratedKeys();
        if (rs.next()){
            risultato=rs.getInt(1);
        }
        rs.close();

        stmt.close();
    } catch (Exception e) {
        e.printStackTrace();
        errore = e.getMessage();
        risultato=-1;
    }
  return risultato;
}
Run Code Online (Sandbox Code Playgroud)

事实上,每一次risultato = -1,我都会得到java.sql.SQLException: Generated keys not requested. You need to specify Statement.RETURN_GENERATED_KEYS to Statement.executeUpdate() or …

java mysql jdbc

87
推荐指数
2
解决办法
16万
查看次数

标签 统计

java ×1

jdbc ×1

mysql ×1