Using a Loop to Set Values : Batch Update « Database « Java Tutorial






import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.Statement;

public class Main {
  public static void main(String[] args) throws Exception {
    Connection conn = getConnection();
    conn.setAutoCommit(false);
    Statement st = conn .createStatement();
    
    
    st.executeUpdate("create table survey (id int, name VARCHAR(30) );");
    
    String INSERT_RECORD = "insert into survey(id, name) values(?,?)";
    
    PreparedStatement pstmt = conn.prepareStatement(INSERT_RECORD);

    for(int i=0;i<10;i++){
      pstmt.setInt(1, i);
      pstmt.setString(2, "name"+i);
      pstmt.executeUpdate();
    }



    ResultSet rs = st.executeQuery("SELECT * FROM survey");
    outputResultSet(rs);

    
    rs.close();
    st.close();
    conn.close();
  }
  private static void outputResultSet(ResultSet rs) throws Exception {
    ResultSetMetaData rsMetaData = rs.getMetaData();
    int numberOfColumns = rsMetaData.getColumnCount();
    for (int i = 1; i < numberOfColumns + 1; i++) {
      String columnName = rsMetaData.getColumnName(i);
      System.out.print(columnName + "   ");

    }
    System.out.println();
    System.out.println("----------------------");

    while (rs.next()) {
      for (int i = 1; i < numberOfColumns + 1; i++) {
        System.out.print(rs.getString(i) + "   ");
      }
      System.out.println();
    }

  }

  private static Connection getConnection() throws Exception {
    Class.forName("org.hsqldb.jdbcDriver");
    String url = "jdbc:hsqldb:mem:data/tutorial";

    return DriverManager.getConnection(url, "sa", "");
  }
}
ID   NAME   
----------------------
0   name0   
1   name1   
2   name2   
3   name3   
4   name4   
5   name5   
6   name6   
7   name7   
8   name8   
9   name9








20.15.Batch Update
20.15.1.Determining If a Database Supports Scrollable Result Sets
20.15.2.Use Batch Multiple Updates with PreparedStatement
20.15.3.Using a Loop to Set Values
20.15.4.Check Batch Update count
20.15.5.Add batch SQL command into Statement
20.15.6.Check BatchUpdateException