首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >MySQL & Java -获取最后插入的值的id (JDBC)

MySQL & Java -获取最后插入的值的id (JDBC)
EN

Stack Overflow用户
提问于 2010-11-22 22:49:43
回答 2查看 173.2K关注 0票数 101

可能重复:

How to get the insert ID in JDBC?

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

现在,我执行了一些insert查询,我需要获取最后插入的值的id (因此,在stmt.executeUpdate之后)。

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

我只需要检索与最后一次插入相关联的id (关于我的语句实例)。

我试过了,但它在JDBC上似乎不起作用:

代码语言:javascript
复制
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;
}

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

我如何解决这个问题?感谢Stackoverflow用户:)

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2010-11-22 22:53:10

你会不会改变一下:

代码语言:javascript
复制
numero = stmt.executeUpdate(query);

至:

代码语言:javascript
复制
numero = stmt.executeUpdate(query, Statement.RETURN_GENERATED_KEYS);

请看一下JDBC Statement接口的文档。

更新:显然,这个答案有很多混乱之处,但我猜困惑的人不会在提出的问题的上下文中阅读它。如果您采用OP在他的问题中提供的代码,并替换我建议的单行(第6行),则一切都会正常工作。numero变量是完全无关紧要的,它的值在设置之后永远不会被读取。

票数 179
EN

Stack Overflow用户

发布于 2010-11-22 22:58:50

或者,您可以执行以下操作:

代码语言:javascript
复制
Statement stmt = db.prepareStatement(query, Statement.RETURN_GENERATED_KEYS);
numero = stmt.executeUpdate();

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

但是使用Sean Bright的答案来代替你的场景。

票数 145
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/4246646

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档