<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
		<id>http://jexp.ru/index.php?action=history&amp;feed=atom&amp;title=Java_Tutorial%2FDatabase%2FBatch_Update</id>
		<title>Java Tutorial/Database/Batch Update - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://jexp.ru/index.php?action=history&amp;feed=atom&amp;title=Java_Tutorial%2FDatabase%2FBatch_Update"/>
		<link rel="alternate" type="text/html" href="http://jexp.ru/index.php?title=Java_Tutorial/Database/Batch_Update&amp;action=history"/>
		<updated>2026-04-07T20:25:23Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://jexp.ru/index.php?title=Java_Tutorial/Database/Batch_Update&amp;diff=4772&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://jexp.ru/index.php?title=Java_Tutorial/Database/Batch_Update&amp;diff=4772&amp;oldid=prev"/>
				<updated>2010-06-01T05:05:52Z</updated>
		
		<summary type="html">&lt;p&gt;1 версия&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr style=&quot;vertical-align: top;&quot; lang=&quot;ru&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;← Предыдущая&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;Версия 05:05, 1 июня 2010&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; style=&quot;text-align: center;&quot; lang=&quot;ru&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(нет различий)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	<entry>
		<id>http://jexp.ru/index.php?title=Java_Tutorial/Database/Batch_Update&amp;diff=4771&amp;oldid=prev</id>
		<title> в 17:44, 31 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://jexp.ru/index.php?title=Java_Tutorial/Database/Batch_Update&amp;diff=4771&amp;oldid=prev"/>
				<updated>2010-05-31T17:44:27Z</updated>
		
		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Новая страница&lt;/b&gt;&lt;/p&gt;&lt;div&gt;==  Add batch SQL command into Statement ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
import java.sql.Connection;&lt;br /&gt;
import java.sql.DriverManager;&lt;br /&gt;
import java.sql.PreparedStatement;&lt;br /&gt;
import java.sql.ResultSet;&lt;br /&gt;
import java.sql.ResultSetMetaData;&lt;br /&gt;
import java.sql.Statement;&lt;br /&gt;
public class Main {&lt;br /&gt;
  public static void main(String[] args) throws Exception {&lt;br /&gt;
    Connection conn = getConnection();&lt;br /&gt;
    conn.setAutoCommit(false);&lt;br /&gt;
    Statement st = conn .createStatement();&lt;br /&gt;
    &lt;br /&gt;
    &lt;br /&gt;
    st.executeUpdate(&amp;quot;create table survey (id int, name VARCHAR(30) );&amp;quot;);&lt;br /&gt;
    st.addBatch(&amp;quot;DELETE FROM survey&amp;quot;);&lt;br /&gt;
    st.addBatch(&amp;quot;INSERT INTO survey(id, name) &amp;quot;+&lt;br /&gt;
                  &amp;quot;VALUES(444, &amp;quot;ginger&amp;quot;)&amp;quot;);&lt;br /&gt;
    // we intentionally pass a table name (animals_tableZZ)&lt;br /&gt;
    // that does not exist&lt;br /&gt;
    st.addBatch(&amp;quot;INSERT INTO survey(id, name) &amp;quot;+&lt;br /&gt;
                  &amp;quot;VALUES(555, &amp;quot;lola&amp;quot;)&amp;quot;);&lt;br /&gt;
    st.addBatch(&amp;quot;INSERT INTO survey(id, name) &amp;quot;+&lt;br /&gt;
                  &amp;quot;VALUES(666, &amp;quot;freddy&amp;quot;)&amp;quot;);&lt;br /&gt;
    // Execute the batch&lt;br /&gt;
    int[] updateCounts = st.executeBatch();&lt;br /&gt;
    &lt;br /&gt;
    checkUpdateCounts(updateCounts);&lt;br /&gt;
    // since there were no errors, commit&lt;br /&gt;
    conn.rumit();&lt;br /&gt;
    &lt;br /&gt;
    ResultSet rs = st.executeQuery(&amp;quot;SELECT * FROM survey&amp;quot;);&lt;br /&gt;
    outputResultSet(rs);&lt;br /&gt;
    &lt;br /&gt;
    rs.close();&lt;br /&gt;
    st.close();&lt;br /&gt;
    conn.close();&lt;br /&gt;
  }&lt;br /&gt;
  public static void checkUpdateCounts(int[] updateCounts) {&lt;br /&gt;
    for (int i=0; i&amp;lt;updateCounts.length; i++) {&lt;br /&gt;
        if (updateCounts[i] &amp;gt;= 0) {&lt;br /&gt;
            System.out.println(&amp;quot;OK; updateCount=&amp;quot;+updateCounts[i]);&lt;br /&gt;
        }&lt;br /&gt;
        else if (updateCounts[i] == Statement.SUCCESS_NO_INFO) {&lt;br /&gt;
            System.out.println(&amp;quot;OK; updateCount=Statement.SUCCESS_NO_INFO&amp;quot;);&lt;br /&gt;
        }&lt;br /&gt;
        else if (updateCounts[i] == Statement.EXECUTE_FAILED) {&lt;br /&gt;
            System.out.println(&amp;quot;Failure; updateCount=Statement.EXECUTE_FAILED&amp;quot;);&lt;br /&gt;
        }&lt;br /&gt;
    }&lt;br /&gt;
}  &lt;br /&gt;
  &lt;br /&gt;
  private static void outputResultSet(ResultSet rs) throws Exception {&lt;br /&gt;
    ResultSetMetaData rsMetaData = rs.getMetaData();&lt;br /&gt;
    int numberOfColumns = rsMetaData.getColumnCount();&lt;br /&gt;
    for (int i = 1; i &amp;lt; numberOfColumns + 1; i++) {&lt;br /&gt;
      String columnName = rsMetaData.getColumnName(i);&lt;br /&gt;
      System.out.print(columnName + &amp;quot;   &amp;quot;);&lt;br /&gt;
    }&lt;br /&gt;
    System.out.println();&lt;br /&gt;
    System.out.println(&amp;quot;----------------------&amp;quot;);&lt;br /&gt;
    while (rs.next()) {&lt;br /&gt;
      for (int i = 1; i &amp;lt; numberOfColumns + 1; i++) {&lt;br /&gt;
        System.out.print(rs.getString(i) + &amp;quot;   &amp;quot;);&lt;br /&gt;
      }&lt;br /&gt;
      System.out.println();&lt;br /&gt;
    }&lt;br /&gt;
  }&lt;br /&gt;
  private static Connection getConnection() throws Exception {&lt;br /&gt;
    Class.forName(&amp;quot;org.hsqldb.jdbcDriver&amp;quot;);&lt;br /&gt;
    String url = &amp;quot;jdbc:hsqldb:mem:data/tutorial&amp;quot;;&lt;br /&gt;
    return DriverManager.getConnection(url, &amp;quot;sa&amp;quot;, &amp;quot;&amp;quot;);&lt;br /&gt;
  }&lt;br /&gt;
}&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre class=codeResult&amp;gt;OK; updateCount=0&lt;br /&gt;
OK; updateCount=1&lt;br /&gt;
OK; updateCount=1&lt;br /&gt;
OK; updateCount=1&lt;br /&gt;
ID   NAME   &lt;br /&gt;
----------------------&lt;br /&gt;
444   ginger   &lt;br /&gt;
555   lola   &lt;br /&gt;
666   freddy&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==  Check Batch Update count ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
import java.sql.Connection;&lt;br /&gt;
import java.sql.DriverManager;&lt;br /&gt;
import java.sql.PreparedStatement;&lt;br /&gt;
import java.sql.ResultSet;&lt;br /&gt;
import java.sql.ResultSetMetaData;&lt;br /&gt;
import java.sql.Statement;&lt;br /&gt;
public class Main {&lt;br /&gt;
  public static void main(String[] args) throws Exception {&lt;br /&gt;
    Connection conn = getConnection();&lt;br /&gt;
    conn.setAutoCommit(false);&lt;br /&gt;
    Statement st = conn .createStatement();&lt;br /&gt;
    &lt;br /&gt;
    &lt;br /&gt;
    st.executeUpdate(&amp;quot;create table survey (id int, name VARCHAR(30) );&amp;quot;);&lt;br /&gt;
    &lt;br /&gt;
    String INSERT_RECORD = &amp;quot;insert into survey(id, name) values(?,?)&amp;quot;;&lt;br /&gt;
    &lt;br /&gt;
    PreparedStatement pstmt = conn.prepareStatement(INSERT_RECORD);&lt;br /&gt;
    pstmt.setString(1, &amp;quot;1&amp;quot;);&lt;br /&gt;
    pstmt.setString(2, &amp;quot;name1&amp;quot;);&lt;br /&gt;
    pstmt.addBatch();&lt;br /&gt;
    &lt;br /&gt;
    pstmt.setString(1, &amp;quot;2&amp;quot;);&lt;br /&gt;
    pstmt.setString(2, &amp;quot;name2&amp;quot;);&lt;br /&gt;
    pstmt.addBatch();&lt;br /&gt;
    &lt;br /&gt;
    // execute the batch&lt;br /&gt;
    int[] updateCounts = pstmt.executeBatch();&lt;br /&gt;
    checkUpdateCounts(updateCounts);&lt;br /&gt;
    // since there were no errors, commit&lt;br /&gt;
    conn.rumit();&lt;br /&gt;
    &lt;br /&gt;
    ResultSet rs = st.executeQuery(&amp;quot;SELECT * FROM survey&amp;quot;);&lt;br /&gt;
    outputResultSet(rs);&lt;br /&gt;
    &lt;br /&gt;
    rs.close();&lt;br /&gt;
    st.close();&lt;br /&gt;
    conn.close();&lt;br /&gt;
  }&lt;br /&gt;
  public static void checkUpdateCounts(int[] updateCounts) {&lt;br /&gt;
    for (int i=0; i&amp;lt;updateCounts.length; i++) {&lt;br /&gt;
        if (updateCounts[i] &amp;gt;= 0) {&lt;br /&gt;
            System.out.println(&amp;quot;OK; updateCount=&amp;quot;+updateCounts[i]);&lt;br /&gt;
        }&lt;br /&gt;
        else if (updateCounts[i] == Statement.SUCCESS_NO_INFO) {&lt;br /&gt;
            System.out.println(&amp;quot;OK; updateCount=Statement.SUCCESS_NO_INFO&amp;quot;);&lt;br /&gt;
        }&lt;br /&gt;
        else if (updateCounts[i] == Statement.EXECUTE_FAILED) {&lt;br /&gt;
            System.out.println(&amp;quot;Failure; updateCount=Statement.EXECUTE_FAILED&amp;quot;);&lt;br /&gt;
        }&lt;br /&gt;
    }&lt;br /&gt;
}  &lt;br /&gt;
  &lt;br /&gt;
  private static void outputResultSet(ResultSet rs) throws Exception {&lt;br /&gt;
    ResultSetMetaData rsMetaData = rs.getMetaData();&lt;br /&gt;
    int numberOfColumns = rsMetaData.getColumnCount();&lt;br /&gt;
    for (int i = 1; i &amp;lt; numberOfColumns + 1; i++) {&lt;br /&gt;
      String columnName = rsMetaData.getColumnName(i);&lt;br /&gt;
      System.out.print(columnName + &amp;quot;   &amp;quot;);&lt;br /&gt;
    }&lt;br /&gt;
    System.out.println();&lt;br /&gt;
    System.out.println(&amp;quot;----------------------&amp;quot;);&lt;br /&gt;
    while (rs.next()) {&lt;br /&gt;
      for (int i = 1; i &amp;lt; numberOfColumns + 1; i++) {&lt;br /&gt;
        System.out.print(rs.getString(i) + &amp;quot;   &amp;quot;);&lt;br /&gt;
      }&lt;br /&gt;
      System.out.println();&lt;br /&gt;
    }&lt;br /&gt;
  }&lt;br /&gt;
  private static Connection getConnection() throws Exception {&lt;br /&gt;
    Class.forName(&amp;quot;org.hsqldb.jdbcDriver&amp;quot;);&lt;br /&gt;
    String url = &amp;quot;jdbc:hsqldb:mem:data/tutorial&amp;quot;;&lt;br /&gt;
    return DriverManager.getConnection(url, &amp;quot;sa&amp;quot;, &amp;quot;&amp;quot;);&lt;br /&gt;
  }&lt;br /&gt;
}&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre class=codeResult&amp;gt;OK; updateCount=1&lt;br /&gt;
OK; updateCount=1&lt;br /&gt;
ID   NAME   &lt;br /&gt;
----------------------&lt;br /&gt;
1   name1   &lt;br /&gt;
2   name2&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==  Check BatchUpdateException ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
import java.sql.BatchUpdateException;&lt;br /&gt;
import java.sql.Connection;&lt;br /&gt;
import java.sql.DriverManager;&lt;br /&gt;
import java.sql.PreparedStatement;&lt;br /&gt;
import java.sql.ResultSet;&lt;br /&gt;
import java.sql.ResultSetMetaData;&lt;br /&gt;
import java.sql.Statement;&lt;br /&gt;
public class Main {&lt;br /&gt;
  public static void main(String[] args) throws Exception {&lt;br /&gt;
    Connection conn = getConnection();&lt;br /&gt;
    conn.setAutoCommit(false);&lt;br /&gt;
    Statement st = conn.createStatement();&lt;br /&gt;
    st.executeUpdate(&amp;quot;create table survey (id int, name VARCHAR(30) );&amp;quot;);&lt;br /&gt;
    String INSERT_RECORD = &amp;quot;insert into survey(id, name) values(?,?)&amp;quot;;&lt;br /&gt;
    PreparedStatement pstmt = conn.prepareStatement(INSERT_RECORD);&lt;br /&gt;
    pstmt.setString(1, &amp;quot;1&amp;quot;);&lt;br /&gt;
    pstmt.setString(2, &amp;quot;name1&amp;quot;);&lt;br /&gt;
    pstmt.addBatch();&lt;br /&gt;
    pstmt.setString(1, &amp;quot;2&amp;quot;);&lt;br /&gt;
    pstmt.setString(2, &amp;quot;name2&amp;quot;);&lt;br /&gt;
    pstmt.addBatch();&lt;br /&gt;
    try {&lt;br /&gt;
      // execute the batch&lt;br /&gt;
      int[] updateCounts = pstmt.executeBatch();&lt;br /&gt;
    } catch (BatchUpdateException e) {&lt;br /&gt;
      int[] updateCounts = e.getUpdateCounts();&lt;br /&gt;
      checkUpdateCounts(updateCounts);&lt;br /&gt;
      try {&lt;br /&gt;
        conn.rollback();&lt;br /&gt;
      } catch (Exception e2) {&lt;br /&gt;
        e.printStackTrace();&lt;br /&gt;
        System.exit(1);&lt;br /&gt;
      }&lt;br /&gt;
    }&lt;br /&gt;
    // since there were no errors, commit&lt;br /&gt;
    conn.rumit();&lt;br /&gt;
    ResultSet rs = st.executeQuery(&amp;quot;SELECT * FROM survey&amp;quot;);&lt;br /&gt;
    outputResultSet(rs);&lt;br /&gt;
    rs.close();&lt;br /&gt;
    st.close();&lt;br /&gt;
    conn.close();&lt;br /&gt;
  }&lt;br /&gt;
  public static void checkUpdateCounts(int[] updateCounts) {&lt;br /&gt;
    for (int i = 0; i &amp;lt; updateCounts.length; i++) {&lt;br /&gt;
      if (updateCounts[i] &amp;gt;= 0) {&lt;br /&gt;
        System.out.println(&amp;quot;OK; updateCount=&amp;quot; + updateCounts[i]);&lt;br /&gt;
      } else if (updateCounts[i] == Statement.SUCCESS_NO_INFO) {&lt;br /&gt;
        System.out.println(&amp;quot;OK; updateCount=Statement.SUCCESS_NO_INFO&amp;quot;);&lt;br /&gt;
      } else if (updateCounts[i] == Statement.EXECUTE_FAILED) {&lt;br /&gt;
        System.out.println(&amp;quot;Failure; updateCount=Statement.EXECUTE_FAILED&amp;quot;);&lt;br /&gt;
      }&lt;br /&gt;
    }&lt;br /&gt;
  }&lt;br /&gt;
  private static void outputResultSet(ResultSet rs) throws Exception {&lt;br /&gt;
    ResultSetMetaData rsMetaData = rs.getMetaData();&lt;br /&gt;
    int numberOfColumns = rsMetaData.getColumnCount();&lt;br /&gt;
    for (int i = 1; i &amp;lt; numberOfColumns + 1; i++) {&lt;br /&gt;
      String columnName = rsMetaData.getColumnName(i);&lt;br /&gt;
      System.out.print(columnName + &amp;quot;   &amp;quot;);&lt;br /&gt;
    }&lt;br /&gt;
    System.out.println();&lt;br /&gt;
    System.out.println(&amp;quot;----------------------&amp;quot;);&lt;br /&gt;
    while (rs.next()) {&lt;br /&gt;
      for (int i = 1; i &amp;lt; numberOfColumns + 1; i++) {&lt;br /&gt;
        System.out.print(rs.getString(i) + &amp;quot;   &amp;quot;);&lt;br /&gt;
      }&lt;br /&gt;
      System.out.println();&lt;br /&gt;
    }&lt;br /&gt;
  }&lt;br /&gt;
  private static Connection getConnection() throws Exception {&lt;br /&gt;
    Class.forName(&amp;quot;org.hsqldb.jdbcDriver&amp;quot;);&lt;br /&gt;
    String url = &amp;quot;jdbc:hsqldb:mem:data/tutorial&amp;quot;;&lt;br /&gt;
    return DriverManager.getConnection(url, &amp;quot;sa&amp;quot;, &amp;quot;&amp;quot;);&lt;br /&gt;
  }&lt;br /&gt;
}&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre class=codeResult&amp;gt;ID   NAME   &lt;br /&gt;
----------------------&lt;br /&gt;
1   name1   &lt;br /&gt;
2   name2&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==  Determining If a Database Supports Scrollable Result Sets ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
import java.sql.Connection;&lt;br /&gt;
import java.sql.DatabaseMetaData;&lt;br /&gt;
import java.sql.DriverManager;&lt;br /&gt;
import java.sql.ResultSet;&lt;br /&gt;
public class Main {&lt;br /&gt;
  public static void main(String[] argv) throws Exception {&lt;br /&gt;
    String driverName = &amp;quot;com.jnetdirect.jsql.JSQLDriver&amp;quot;;&lt;br /&gt;
    Class.forName(driverName);&lt;br /&gt;
    String serverName = &amp;quot;127.0.0.1&amp;quot;;&lt;br /&gt;
    String portNumber = &amp;quot;1433&amp;quot;;&lt;br /&gt;
    String mydatabase = serverName + &amp;quot;:&amp;quot; + portNumber;&lt;br /&gt;
    String url = &amp;quot;jdbc:JSQLConnect://&amp;quot; + mydatabase;&lt;br /&gt;
    String username = &amp;quot;username&amp;quot;;&lt;br /&gt;
    String password = &amp;quot;password&amp;quot;;&lt;br /&gt;
    Connection connection = DriverManager.getConnection(url, username, password);&lt;br /&gt;
    DatabaseMetaData dmd = connection.getMetaData();&lt;br /&gt;
    if (dmd.supportsResultSetType(ResultSet.TYPE_SCROLL_INSENSITIVE)) {&lt;br /&gt;
        System.out.println(&amp;quot;Insensitive scrollable result sets are supported&amp;quot;);&lt;br /&gt;
    }&lt;br /&gt;
    if (dmd.supportsResultSetType(ResultSet.TYPE_SCROLL_SENSITIVE)) {&lt;br /&gt;
        System.out.println(&amp;quot;Sensitive scrollable result sets are supported&amp;quot;); &lt;br /&gt;
    }&lt;br /&gt;
    if (!dmd.supportsResultSetType(ResultSet.TYPE_SCROLL_INSENSITIVE)&lt;br /&gt;
        &amp;amp;&amp;amp; !dmd.supportsResultSetType(ResultSet.TYPE_SCROLL_SENSITIVE)) {&lt;br /&gt;
        System.out.println(&amp;quot;Updatable result sets are not supported&amp;quot;);&lt;br /&gt;
    }&lt;br /&gt;
  }&lt;br /&gt;
}&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==  Use Batch Multiple Updates with PreparedStatement ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
import java.sql.Connection;&lt;br /&gt;
import java.sql.DriverManager;&lt;br /&gt;
import java.sql.PreparedStatement;&lt;br /&gt;
import java.sql.ResultSet;&lt;br /&gt;
import java.sql.ResultSetMetaData;&lt;br /&gt;
import java.sql.Statement;&lt;br /&gt;
public class Main {&lt;br /&gt;
  public static void main(String[] args) throws Exception {&lt;br /&gt;
    Connection conn = getConnection();&lt;br /&gt;
    conn.setAutoCommit(false);&lt;br /&gt;
    Statement st = conn .createStatement();&lt;br /&gt;
    &lt;br /&gt;
    &lt;br /&gt;
    st.executeUpdate(&amp;quot;create table survey (id int, name VARCHAR(30) );&amp;quot;);&lt;br /&gt;
    &lt;br /&gt;
    String INSERT_RECORD = &amp;quot;insert into survey(id, name) values(?,?)&amp;quot;;&lt;br /&gt;
    &lt;br /&gt;
    PreparedStatement pstmt = conn.prepareStatement(INSERT_RECORD);&lt;br /&gt;
    pstmt.setString(1, &amp;quot;1&amp;quot;);&lt;br /&gt;
    pstmt.setString(2, &amp;quot;name1&amp;quot;);&lt;br /&gt;
    pstmt.addBatch();&lt;br /&gt;
    &lt;br /&gt;
    pstmt.setString(1, &amp;quot;2&amp;quot;);&lt;br /&gt;
    pstmt.setString(2, &amp;quot;name2&amp;quot;);&lt;br /&gt;
    pstmt.addBatch();&lt;br /&gt;
    &lt;br /&gt;
    // execute the batch&lt;br /&gt;
    int[] updateCounts = pstmt.executeBatch();&lt;br /&gt;
    checkUpdateCounts(updateCounts);&lt;br /&gt;
    // since there were no errors, commit&lt;br /&gt;
    conn.rumit();&lt;br /&gt;
    &lt;br /&gt;
    ResultSet rs = st.executeQuery(&amp;quot;SELECT * FROM survey&amp;quot;);&lt;br /&gt;
    outputResultSet(rs);&lt;br /&gt;
    &lt;br /&gt;
    rs.close();&lt;br /&gt;
    st.close();&lt;br /&gt;
    conn.close();&lt;br /&gt;
  }&lt;br /&gt;
  public static void checkUpdateCounts(int[] updateCounts) {&lt;br /&gt;
    for (int i=0; i&amp;lt;updateCounts.length; i++) {&lt;br /&gt;
        if (updateCounts[i] &amp;gt;= 0) {&lt;br /&gt;
            System.out.println(&amp;quot;OK; updateCount=&amp;quot;+updateCounts[i]);&lt;br /&gt;
        }&lt;br /&gt;
        else if (updateCounts[i] == Statement.SUCCESS_NO_INFO) {&lt;br /&gt;
            System.out.println(&amp;quot;OK; updateCount=Statement.SUCCESS_NO_INFO&amp;quot;);&lt;br /&gt;
        }&lt;br /&gt;
        else if (updateCounts[i] == Statement.EXECUTE_FAILED) {&lt;br /&gt;
            System.out.println(&amp;quot;Failure; updateCount=Statement.EXECUTE_FAILED&amp;quot;);&lt;br /&gt;
        }&lt;br /&gt;
    }&lt;br /&gt;
}  &lt;br /&gt;
  &lt;br /&gt;
  private static void outputResultSet(ResultSet rs) throws Exception {&lt;br /&gt;
    ResultSetMetaData rsMetaData = rs.getMetaData();&lt;br /&gt;
    int numberOfColumns = rsMetaData.getColumnCount();&lt;br /&gt;
    for (int i = 1; i &amp;lt; numberOfColumns + 1; i++) {&lt;br /&gt;
      String columnName = rsMetaData.getColumnName(i);&lt;br /&gt;
      System.out.print(columnName + &amp;quot;   &amp;quot;);&lt;br /&gt;
    }&lt;br /&gt;
    System.out.println();&lt;br /&gt;
    System.out.println(&amp;quot;----------------------&amp;quot;);&lt;br /&gt;
    while (rs.next()) {&lt;br /&gt;
      for (int i = 1; i &amp;lt; numberOfColumns + 1; i++) {&lt;br /&gt;
        System.out.print(rs.getString(i) + &amp;quot;   &amp;quot;);&lt;br /&gt;
      }&lt;br /&gt;
      System.out.println();&lt;br /&gt;
    }&lt;br /&gt;
  }&lt;br /&gt;
  private static Connection getConnection() throws Exception {&lt;br /&gt;
    Class.forName(&amp;quot;org.hsqldb.jdbcDriver&amp;quot;);&lt;br /&gt;
    String url = &amp;quot;jdbc:hsqldb:mem:data/tutorial&amp;quot;;&lt;br /&gt;
    return DriverManager.getConnection(url, &amp;quot;sa&amp;quot;, &amp;quot;&amp;quot;);&lt;br /&gt;
  }&lt;br /&gt;
}&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre class=codeResult&amp;gt;OK; updateCount=1&lt;br /&gt;
OK; updateCount=1&lt;br /&gt;
ID   NAME   &lt;br /&gt;
----------------------&lt;br /&gt;
1   name1   &lt;br /&gt;
2   name2&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==  Using a Loop to Set Values ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
import java.sql.Connection;&lt;br /&gt;
import java.sql.DriverManager;&lt;br /&gt;
import java.sql.PreparedStatement;&lt;br /&gt;
import java.sql.ResultSet;&lt;br /&gt;
import java.sql.ResultSetMetaData;&lt;br /&gt;
import java.sql.Statement;&lt;br /&gt;
public class Main {&lt;br /&gt;
  public static void main(String[] args) throws Exception {&lt;br /&gt;
    Connection conn = getConnection();&lt;br /&gt;
    conn.setAutoCommit(false);&lt;br /&gt;
    Statement st = conn .createStatement();&lt;br /&gt;
    &lt;br /&gt;
    &lt;br /&gt;
    st.executeUpdate(&amp;quot;create table survey (id int, name VARCHAR(30) );&amp;quot;);&lt;br /&gt;
    &lt;br /&gt;
    String INSERT_RECORD = &amp;quot;insert into survey(id, name) values(?,?)&amp;quot;;&lt;br /&gt;
    &lt;br /&gt;
    PreparedStatement pstmt = conn.prepareStatement(INSERT_RECORD);&lt;br /&gt;
    for(int i=0;i&amp;lt;10;i++){&lt;br /&gt;
      pstmt.setInt(1, i);&lt;br /&gt;
      pstmt.setString(2, &amp;quot;name&amp;quot;+i);&lt;br /&gt;
      pstmt.executeUpdate();&lt;br /&gt;
    }&lt;br /&gt;
&lt;br /&gt;
    ResultSet rs = st.executeQuery(&amp;quot;SELECT * FROM survey&amp;quot;);&lt;br /&gt;
    outputResultSet(rs);&lt;br /&gt;
    &lt;br /&gt;
    rs.close();&lt;br /&gt;
    st.close();&lt;br /&gt;
    conn.close();&lt;br /&gt;
  }&lt;br /&gt;
  private static void outputResultSet(ResultSet rs) throws Exception {&lt;br /&gt;
    ResultSetMetaData rsMetaData = rs.getMetaData();&lt;br /&gt;
    int numberOfColumns = rsMetaData.getColumnCount();&lt;br /&gt;
    for (int i = 1; i &amp;lt; numberOfColumns + 1; i++) {&lt;br /&gt;
      String columnName = rsMetaData.getColumnName(i);&lt;br /&gt;
      System.out.print(columnName + &amp;quot;   &amp;quot;);&lt;br /&gt;
    }&lt;br /&gt;
    System.out.println();&lt;br /&gt;
    System.out.println(&amp;quot;----------------------&amp;quot;);&lt;br /&gt;
    while (rs.next()) {&lt;br /&gt;
      for (int i = 1; i &amp;lt; numberOfColumns + 1; i++) {&lt;br /&gt;
        System.out.print(rs.getString(i) + &amp;quot;   &amp;quot;);&lt;br /&gt;
      }&lt;br /&gt;
      System.out.println();&lt;br /&gt;
    }&lt;br /&gt;
  }&lt;br /&gt;
  private static Connection getConnection() throws Exception {&lt;br /&gt;
    Class.forName(&amp;quot;org.hsqldb.jdbcDriver&amp;quot;);&lt;br /&gt;
    String url = &amp;quot;jdbc:hsqldb:mem:data/tutorial&amp;quot;;&lt;br /&gt;
    return DriverManager.getConnection(url, &amp;quot;sa&amp;quot;, &amp;quot;&amp;quot;);&lt;br /&gt;
  }&lt;br /&gt;
}&amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre class=codeResult&amp;gt;ID   NAME   &lt;br /&gt;
----------------------&lt;br /&gt;
0   name0   &lt;br /&gt;
1   name1   &lt;br /&gt;
2   name2   &lt;br /&gt;
3   name3   &lt;br /&gt;
4   name4   &lt;br /&gt;
5   name5   &lt;br /&gt;
6   name6   &lt;br /&gt;
7   name7   &lt;br /&gt;
8   name8   &lt;br /&gt;
9   name9&amp;lt;/pre&amp;gt;&lt;/div&gt;</summary>
			</entry>

	</feed>