jdbcexecuteBatch()事务批量提交获取到其中⼀条存在异常sql
import java.sql.BatchUpdateException;
try{
connectionmit();//提交
}catch (BatchUpdateException throwables) {
int[] exc = UpdateCounts();//获取到sql执⾏后返回的信息
int count =0;
//遍历获取到第⼏条sql有问题
for(int i =0; i < exc.length; i++) {
if(exc[i]!=1) {
count = i+1;
break;
批量更新sql语句}
}
//最后⾃⼰检查这条数据存在的问题
}
官⽅⽂档说明
public int[]<b>getUpdateCounts</b>()
获取发⽣此异常前批量更新中成功执⾏的每个更新语句的更新计数。在某⼀命令⽆法正确执⾏时,实现批量更新的驱动程序可以继续处理批处理中的剩余命令,也可以不再进⾏处理。如果驱动程序继续处理命令,那么此⽅法返回的数组所拥有的元素数量将与批处理中的命令数量相同;否则,该数组将包含抛出 BatchUpdateException 之前成功执⾏的每条命令的更新计数。
此⽅法的可能返回值是在 Java 2 SDK 标准版 1.3 版中修改的。这样做是为了使其适应在抛出了 BatchUpdateException 对象之后仍然能够继续处理批量更新中的命令这⼀新选项。
返回:⼀个 int 数组,该数组包含发⽣此错误前成功执⾏的更新的更新计数。如果驱动程序在发⽣错误之后仍然继续处理命令,则对批处理中的每条命令返回以下内容之⼀:
1 更新计数
2 Statement.SUCCESS_NO_INFO,指⽰成功执⾏了命令,但受影响的⾏数是未知的
3 Statement.EXECUTE_FAILED,指⽰没有成功地执⾏命令
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论