gpt4 book ai didi

java - 从 BatchUpdateException 确定每行执行失败的原因

转载 作者:行者123 更新时间:2023-11-29 20:13:18 25 4
gpt4 key购买 nike

我有一个 java 程序,可以将文本文件中的数千行数据读取到数据库中。它使用语句批处理一次插入几千行。

如果任何行无法更新,我将继续尝试其余行,直到列表末尾。之后,我返回并检查哪些行失败,然后将这些行中的信息打印到日志文件中以供稍后检查。

我想知道如果由于重复条目而失败,是否有办法跳过打印失败的行。我可以接受重复失败,但如果插入由于其他原因失败,我需要将该行输出到我的日志文件中。

我目前的做法是:

int[] updateCounts;

try {
// Do my batch updates by iterating through a vector of data
} catch (BatchUpdateException buE) {
updateCounts = buE.getUpdateCounts();
}

for (int c = 0; c < updateCounts.length; ++c) {
if (updateCounts[c] == Statement.EXECUTE_FAILED) {
// Print data from the original data vector at index c
}
}

我不想打印 updateCounts 为 EXECUTE_FAILED 的每一行,而是只想打印由于唯一键而没有的行。

在 Google、StackOverflow 和 BatchUpdateException 文档之间,我猜没有办法做到这一点。但如果有就好了,但我就是找不到。

最佳答案

可能有两个原因;

  1. SQL 查询中可能存在语法错误。
  2. 主键可能有重复条目。

当您从文本文件读取数据时,我建议您在 SQL 中使用加载数据本地 InFile 查询。这将解决上述两个问题,并且您的所有真实条目都将上传到数据库中。

如果这没有帮助,请将查询添加到您的问题中,堆栈跟踪将有助于回答。

关于java - 从 BatchUpdateException 确定每行执行失败的原因,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39947790/

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