Ho bisogno di inserire un paio di centinaia di milioni di record nel mysql db. Sto inserendolo in batch 1 milione alla volta. Si prega di consultare il mio codice qui sotto. Sembra essere lento. C'è un modo per ottimizzarlo?JDBC prestazioni di inserimento batch
try {
// Disable auto-commit
connection.setAutoCommit(false);
// Create a prepared statement
String sql = "INSERT INTO mytable (xxx), VALUES(?)";
PreparedStatement pstmt = connection.prepareStatement(sql);
Object[] vals=set.toArray();
for (int i=0; i<vals.length; i++) {
pstmt.setString(1, vals[i].toString());
pstmt.addBatch();
}
// Execute the batch
int [] updateCounts = pstmt.executeBatch();
System.out.append("inserted "+updateCounts.length);
Il codice è leggermente danneggiato (e troncato prematuramente) – Uri
BTW, quale driver utilizzi? Un JDBC generale o il connettore JDBC-Mysql? – Uri
Sto usando com.mysql.jdbc.Driver – user157195