可能重复:
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上似乎不起作用:
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用户:)
发布于 2010-11-22 22:53:10
你会不会改变一下:
numero = stmt.executeUpdate(query);
至:
numero = stmt.executeUpdate(query, Statement.RETURN_GENERATED_KEYS);
请看一下JDBC Statement
接口的文档。
更新:显然,这个答案有很多混乱之处,但我猜困惑的人不会在提出的问题的上下文中阅读它。如果您采用OP在他的问题中提供的代码,并替换我建议的单行(第6行),则一切都会正常工作。numero
变量是完全无关紧要的,它的值在设置之后永远不会被读取。
发布于 2010-11-22 22:58:50
或者,您可以执行以下操作:
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的答案来代替你的场景。
https://stackoverflow.com/questions/4246646
复制相似问题