jdbc executeBatch()事务批量提交获取到其中一条存在异常sql

import java.sql.BatchUpdateException;
try{
	ps.executeBatch();//批量执行
    connection.commit();//提交
}catch (BatchUpdateException throwables) {
    int[] exc = throwables.getUpdateCounts();//获取到sql执行后返回的信息
    int count = 0;
    //遍历 获取到第几条sql有问题
    for (int i = 0; i < exc.length; i++) {
        if (exc[i] != 1) {
            count = i+1;
            break;
            }
        }
    //最后自己检查这条数据存在的问题    
}

官方文档说明

public int[] <b>getUpdateCounts</b>()

获取发生此异常前批量更新中成功执行的每个更新语句的更新计数。在某一命令无法正确执行时,实现批量更新的驱动程序可以继续处理批处理中的剩余命令,也可以不再进行处理。如果驱动程序继续处理命令,那么此方法返回的数组所拥有的元素数量将与批处理中的命令数量相同;否则,该数组将包含抛出 BatchUpdateException 之前成功执行的每条命令的更新计数。
此方法的可能返回值是在 Java 2 SDK 标准版 1.3 版中修改的。这样做是为了使其适应在抛出了 BatchUpdateException 对象之后仍然能够继续处理批量更新中的命令这一新选项。
返回:一个 int 数组,该数组包含发生此错误前成功执行的更新的更新计数。如果驱动程序在发生错误之后仍然继续处理命令,则对批处理中的每条命令返回以下内容之一:
1 更新计数
2 Statement.SUCCESS_NO_INFO,指示成功执行了命令,但受影响的行数是未知的
3 Statement.EXECUTE_FAILED,指示没有成功地执行命令

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

戏子 丶

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值