Excelシートからデータを抽出し、それらをOracleテーブルに挿入しています。データベースは、バッチステートメントの実行時に、バッチ内の挿入ステートメントのいずれかが失敗した場合に、バッチ内の他のすべてのステートメントが実行されないように設定されています。だから私の問題は、どのデータ行が実際にそれを引き起こしているのかをどのように見つけることができるかということです、それで私は問題を引き起こしているデータの行番号でユーザーにメッセージを送ることができますか?
Connection con = null;
PreparedStatement pstmt = null;
Iterator iterator = list.iterator();
int rowCount = list.size();
int currentRow = 0;
String sqlStatement = "INSERT INTO DMD_VOL_UPLOAD (ORIGIN, DESTINATION, DAY_OF_WEEK, VOLUME)";
sqlStatement += " VALUES(?, ?, ?, ?)";
int batchSize==1000;
for(currentRow=1; currentRow<=rowCount; currentRow++){
ForecastBatch forecastBatch = (ForecastBatch) iterator.next();
pstmt.setString(1, forecastBatch.getOrigin());
pstmt.setString(2, forecastBatch.getDestination());
pstmt.setInt(3, forecastBatch.getDayOfWeek());
pstmt.setInt(4, forecastBatch.getVolumeSum());
pstmt.addBatch();
if(i % batchSize == 0){
updateCounts = pstmt.executeBatch();
con.commit();
pstmt.clearBatch();
session.flush();
session.clear();
}
}