循环中出现异常时记录异常并继续执行循环

 for(AdminDataContent adminDataContent:adminDataContentList){
                 try {
                     String tableName=adminDataContent.getTableName();
                     String sql = "describe " +tableName ;  
                     PreparedStatement ps = conn.prepareStatement(sql);  
                     ResultSet resultset = ps.executeQuery();  
                     while(resultset.next()){
                             AdminDataContentDetail contentDetail=new AdminDataContentDetail();
                             contentDetail.setId(new UUIDUtils().getUUID());
                             contentDetail.setContentId(adminDataContent.getId());
                             contentDetail.setDatasourceId(adminDataContent.getDataSourceId());
                             contentDetail.setColumnName(resultset.getString(1));
                             contentDetail.setColumnType(resultset.getString(2));
                             contentDetail.setCreateBy(adminDataContent.getCreateBy());
                             contentDetail.setCreateDate(new Date());
                             contentDetail.setUpdateBy(adminDataContent.getUpdateBy());
                             contentDetail.setUpdateDate(new Date());
                             contentDetail.setDelFlag("0");
                             contentDetailsList.add(contentDetail);
                               
                         }
                } catch (Exception e) {
                    e.printStackTrace();
                     TableScanError error=new TableScanError();
                    error.setId(new UUIDUtils().getUUID());
                    error.setDataSourceId(adminDataContent.getDataSourceId());
                    error.setErrorTableName(adminDataContent.getTableName());
                    error.setErrorDatabase(StringUtils.substringBefore(adminDataContent.getTableName(), "."));
                    //error.setCreateBy(adminDataContent.getCreateBy());
                    error.setCreateDate(new Date());
                    //error.setUpdateBy(adminDataContent.getUpdateBy());
                    error.setUpdateDate(new Date());
                    error.setRemarks(e.toString());
                    errors.add(error);
                    continue;
                    
                }       
             }

实例如上,在循环中使用try catch,catch中进行异常处理并使用continue进入下一次循环

转载于:https://www.cnblogs.com/dsh2018/p/9396919.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值