gpt4 book ai didi

java - 在 Java 中插入 SQL 后访问自动递增标识字段

转载 作者:太空狗 更新时间:2023-10-29 22:45:03 24 4
gpt4 key购买 nike

关于如何通过 java.sql.Statement.executeUpdate 读取分配给新创建记录的自动递增身份字段的任何建议?

我知道如何在多个数据库平台的 SQL 中执行此操作,但想知道 java.sql 中存在哪些数据库独立接口(interface)来执行此操作,以及有关人们对此的经验的任何输入数据库平台。

最佳答案

下面的代码片段应该可以做到:

PreparedStatement stmt = conn.prepareStatement(sql, 
Statement.RETURN_GENERATED_KEYS);
// ...

ResultSet res = stmt.getGeneratedKeys();
while (res.next())
System.out.println("Generated key: " + res.getInt(1));

已知这适用于以下数据库

  • Derby
  • MySQL
  • SQL Server

对于它不起作用的数据库(HSQLDB、Oracle、PostgreSQL 等),您将需要使用特定于数据库的技巧。例如,在 PostgreSQL 上,您将为相关序列调用 SELECT NEXTVAL(...)

请注意,executeUpdate(...) 的参数是类似的。

关于java - 在 Java 中插入 SQL 后访问自动递增标识字段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/76254/

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