Possible Duplicate:
How to get the insert ID in JDBC?

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

现在,我做了一些插入查询,我需要得到最后一个插入值的id(所以,在stmt.executeUpdate之后).

我不需要SELECT id FROM table ORDER BY id DESC LIMIT 1,因为我可能有并发问题.

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

我试过这个,但在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;
}

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

我如何解决这个问题?谢谢大家:)

推荐答案

你不想改变一下吗:

numero = stmt.executeUpdate(query);

致:

numero = stmt.executeUpdate(query, Statement.RETURN_GENERATED_KEYS);

看看JDBCStatement接口的文档.

Update:显然,这个答案有很多困惑,但我的猜测是,困惑的人没有在被问到的问题的背景下阅读它.如果你采用OP在问题中提供的代码,并替换我建议的单行代码(第6行),那么一切都会成功.numero变量是完全不相关的,它的值在设置后永远不会被读取.

Mysql相关问答推荐

过程/别名是有点长的MySQL命令的一部分吗?

配置MySQL服务器以管理数千个表

SQL:CAST与窗口函数组合导致语法错误

为什么MySQL不考虑在联接中使用(JSON)函数索引,而考虑在生成的列上使用索引?

不分组寻呼

获取连续11天未考勤的员工

SQL:如何 Select 每个客户最后购买的产品?

使用mysql查询获取不关注user1的user3

计算同一个表中的两列,然后将两者都算作总数

Travis 构建失败并出现错误 LOAD DATA LOCAL INFILE 文件请求因访问限制而被拒绝

Mysql JSON_REMOVE 数组键和值 (MariaDB)

如何获取从开始时间到结束时间的所有正在运行的作业(job)的总和?

使用数据表的直方图(SQL 查询)

如何在 MYSQL 中使用多个表进行插值

在 Presto Athena 中将字符串转换为数组

MySQL过滤食谱上的多对多 - 成分表

保存SQL查询的中间结果

什么是 PyMySQL,它与 MySQLdb 有何不同?它会影响 Django 部署吗?

在mysql中增量更新值

在 Ubuntu 上安装 mysql gem 的困难