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

标签 java sql

关于如何通过 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/

相关文章:

java - Java 中的 SSL 自签名过期证书

java - 使用 else 语句创建列表

sql - 查询核心数据中的每个第 n 个元素

java - 基于日期的SQL过滤

java - 使用 IntelliJ 运行 tomcat - 无法启动服务器

java - Eclipse插件中是否需要配置资源

java - 如何使用Servlet批量上传PDF文件并保存到MySQL中?

sql - 在 firebird 中使用 "from"内部的变量

mysql - 如何为这个问题编写 SQL Select Query?

mysql - Sqlite 查询选择语句,其排序结果尊重 OFFSET