java mysql insert id_MySQL和Java-获取最后插入值的ID(JDBC)[重复]

这个问题已经在这里有了答案 :

9年前关闭。

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

现在,我执行一些插入查询,并且需要获取最后插入值的ID(因此,在之后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;

}

实际上,每次risultato = -1,我得到java.sql.SQLException: Generated keys not

requested. You need to specify Statement.RETURN_GENERATED_KEYS to

Statement.executeUpdate() or Connection.prepareStatement().

我该如何解决这个问题?谢谢Stackoverflow人们:)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值