В моей базе данных хранилища данных SQL Azure есть такая таблица:
CREATE TABLE t_identity (
id INTEGER IDENTITY (1, 1) NOT NULL,
val INTEGER
)
Теперь, используя JDBC, я хочу вставить строку и извлечь сгенерированное значение идентификатора.Это будет работать в SQL Server и большинстве других баз данных:
try (Connection c = DriverManager.getConnection(url, properties);
Statement s = c.createStatement()) {
s.executeUpdate("insert into t_identity (val) values (1)",
Statement.RETURN_GENERATED_KEYS);
try (ResultSet rs = s.getGeneratedKeys()) {
while (rs.next())
System.out.println(rs.getObject(1));
}
}
Но в хранилище данных SQL это не работает:
Exception in thread "main" com.microsoft.sqlserver.jdbc.SQLServerException: 'SCOPE_IDENTITY' is not a recognized built-in function name.
at com.microsoft.sqlserver.jdbc.SQLServerException.makeFromDatabaseError(SQLServerException.java:264)
at com.microsoft.sqlserver.jdbc.SQLServerStatement.getNextResult(SQLServerStatement.java:1585)
at com.microsoft.sqlserver.jdbc.SQLServerStatement.doExecuteStatement(SQLServerStatement.java:876)
at com.microsoft.sqlserver.jdbc.SQLServerStatement$StmtExecCmd.doExecute(SQLServerStatement.java:776)
at com.microsoft.sqlserver.jdbc.TDSCommand.execute(IOBuffer.java:7385)
at com.microsoft.sqlserver.jdbc.SQLServerConnection.executeCommand(SQLServerConnection.java:2750)
at com.microsoft.sqlserver.jdbc.SQLServerStatement.executeCommand(SQLServerStatement.java:235)
at com.microsoft.sqlserver.jdbc.SQLServerStatement.executeStatement(SQLServerStatement.java:210)
at com.microsoft.sqlserver.jdbc.SQLServerStatement.executeUpdate(SQLServerStatement.java:2060)
at SQLServer.main(SQLServer.java:65)
Другие методы (например, executeUpdate(String, String[])
) тоже не работают, так как делегируют вышеуказанному.
Я понимаю, что хранилище данных SQL не поддерживает SCOPE_IDENTITY()
и подобные функции ,который, кажется, используется за кулисами драйвером mssql-jdbc:
<dependency>
<groupId>com.microsoft.sqlserver</groupId>
<artifactId>mssql-jdbc</artifactId>
<version>6.5.2.jre8-preview</version>
</dependency>
Но есть ли обходной путь?
Примечания: