gpt4 book ai didi

java - 这个 getGeneratedKeys() JDBC 语句有什么问题?

转载 作者:行者123 更新时间:2023-11-29 04:39:59 24 4
gpt4 key购买 nike

这段代码片段

PreparedStatement statement = connect.prepareStatement(
query, Statement.RETURN_GENERATED_KEYS);
statement.executeUpdate(query);
try (ResultSet generatedKeys = statement.getGeneratedKeys()) {
...
}

继续 throw

java.sql.SQLException: Generated keys not requested. You need to specify Statement.RETURN_GENERATED_KEYS to Statement.executeUpdate() or Connection.prepareStatement().

我会说在创建语句时要求生成 key ,但显然我错了。这里的问题是什么? (我是 JDBC 的新手。我想做的是检索在前面的记录插入期间自动设置(AUTO_INCREMENTed)的主键值。也许有更好的方法来做到这一点......我是使用 mysql。)

最佳答案

你的问题是这一行:

statement.executeUpdate(query);

不要在使用无参数版本时传递query参数:

statement.executeUpdate();

第一个版本不使用您已经创建的准备好的语句,而是使用您的查询字符串创建一个新的语句(没有 RETURN_GENERATED_KEYS 选项)

关于java - 这个 getGeneratedKeys() JDBC 语句有什么问题?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31727617/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com