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