sql - 无法通过 SQL 数据仓库上的 JDBC 获取生成的密钥
问题描述
我的 Azure SQL 数据仓库数据库中有一个这样的表:
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 数据仓库不支持mssql-jdbc 驱动程序在幕后使用的SCOPE_IDENTITY()
和类似的功能:
<dependency>
<groupId>com.microsoft.sqlserver</groupId>
<artifactId>mssql-jdbc</artifactId>
<version>6.5.2.jre8-preview</version>
</dependency>
但是有解决方法吗?
笔记:
解决方案
您能否更详细地描述您的业务用例?如果您使用的是 JOOQ,我认为您的技术可能不匹配。
Azure SQL 数据仓库不适用于事务性工作负载。如果 JOOQ 只是维护一些参考行,那么我看不出有什么问题,但如果这是您的主要数据加载策略,您将不会获得好的结果。
以下是一些可能有帮助的阅读材料:
解决方案模型(滚动到图表):https ://azure.microsoft.com/en-us/services/sql-data-warehouse/
数据加载最佳实践:https ://docs.microsoft.com/en-us/azure/sql-data-warehouse/guidance-for-loading-data
推荐阅读
- python - 硒如果找不到元素= nan
- python - 在 Django 中的 ID 后附加文本
- php - 删除时出错 - 只能通过引用 PHP/MYSQLI 传递变量
- ios - 用 2 个数组快速填充 UItableViewCell
- php - 从 PHP 运行 PSQL 查询
- azure-devops - 无法将 Azure SQL 与 Azure DevOps Server 2019 一起使用 - (Azure 政府)
- bash - 标准输出和标准错误
- excel - 另一个工作表单元格中的公式错误,其中包含带有 activesheet.name 的超链接
- xcode - xcode 10.1 架构 arm64 的未定义符号
- c# - 检测到与 ASP.NET SignalR 服务器的连接尝试。此客户端仅支持连接到 ASP.NET Core SignalR 服务器