我有一个 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 文档之间,我猜没有办法做到这一点。但如果有就好了,但我就是找不到。
最佳答案
可能有两个原因;
- SQL 查询中可能存在语法错误。
- 主键可能有重复条目。
当您从文本文件读取数据时,我建议您在 SQL 中使用加载数据本地 InFile
查询。这将解决上述两个问题,并且您的所有真实条目都将上传到数据库中。
如果这没有帮助,请将查询添加到您的问题中,堆栈跟踪将有助于回答。
关于java - 从 BatchUpdateException 确定每行执行失败的原因,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39947790/