私は約25,000行のExcelシートを持っています。 Excelシートの各行は私のテーブルの行にもなります。私は次のことをやろうとしました。私はbatchSizeを25から50,100,500に変更しようとしました。いずれも動作しません。誰かが私に間違っていることを教えてもらえますか? JVMのヒープサイズを変更することは私の選択肢ではありません。クラスjava.lang.OutOfMemoryError Oracleデータベースにデータを保存中
public void saveForecast(List list) throws FinderException{
final Session session = getCurrentSession();
final int batchSize = 25;
Connection con = null;
PreparedStatement pstmt = null;
Iterator iterator = list.iterator();
int rowCount = list.size();
String sqlStatement = "INSERT INTO DMD_VOL_UPLOAD (ORIGIN, DESTINATION, DAY_OF_WEEK, EFFECTIVE_DATE, DISCONTINUE_DATE, VOLUME)";
sqlStatement += " VALUES(?, ?, ?, ?, ?, ?)";
System.out.println(sqlStatement);
System.out.println("Number of rows to be inserted: "+ rowCount);
System.out.println("Starting time: "+new Date().toString());
try{
con = session.connection();
for(int i=0; i<rowCount; i++){
ForecastBatch forecastBatch = (ForecastBatch) iterator.next();
pstmt = con.prepareStatement(sqlStatement);
pstmt.setString(1, forecastBatch.getOrigin());
pstmt.setString(2, forecastBatch.getDestination());
pstmt.setInt(3, forecastBatch.getDayOfWeek());
java.util.Date effJavaDate = forecastBatch.getEffectiveDate();
java.sql.Date effSqlDate = new java.sql.Date(effJavaDate.getTime());
pstmt.setDate(4, effSqlDate);
java.util.Date disJavaDate=forecastBatch.getDiscontinueDate();
java.sql.Date disSqlDate = new java.sql.Date(disJavaDate.getTime());
pstmt.setDate(5, disSqlDate);
pstmt.setInt(6, forecastBatch.getVolumeSum());
pstmt.addBatch();
if(i % batchSize == 0){
pstmt.executeBatch();
session.flush();
session.clear();
}
}
pstmt.executeBatch();
pstmt.close();
System.out.println("Ending Time: "+ new Date().toString());
}catch(SQLException e){
e.printStackTrace();
throw new FinderException(e);
}
finally{
HibernateUtil.closeSession();
}
}
}
私は1)forループとイテレータを使用してリストをトラバースしています。 r(イテレータに投票します)。また、より小さなExcelファイルではどうなりますか?どのような時点でそれが詰まるのですか? –
ヒープダンプを生成し、メモリプロファイラを使用します。問題の原因を推測する必要はありません。 – jtahlborn
スプレッドシートのディスク上のサイズは?あなたはどのリーダーの実装を使用していますか? – nsfyn55