<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
		<id>http://www.jexp.ru/index.php?action=history&amp;feed=atom&amp;title=Java%2FDatabase_SQL_JDBC%2FSQL_Update</id>
		<title>Java/Database SQL JDBC/SQL Update - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://www.jexp.ru/index.php?action=history&amp;feed=atom&amp;title=Java%2FDatabase_SQL_JDBC%2FSQL_Update"/>
		<link rel="alternate" type="text/html" href="http://www.jexp.ru/index.php?title=Java/Database_SQL_JDBC/SQL_Update&amp;action=history"/>
		<updated>2026-04-21T10:17:10Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://www.jexp.ru/index.php?title=Java/Database_SQL_JDBC/SQL_Update&amp;diff=7001&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://www.jexp.ru/index.php?title=Java/Database_SQL_JDBC/SQL_Update&amp;diff=7001&amp;oldid=prev"/>
				<updated>2010-06-01T06:35:17Z</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;Версия 06:35, 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://www.jexp.ru/index.php?title=Java/Database_SQL_JDBC/SQL_Update&amp;diff=7000&amp;oldid=prev</id>
		<title> в 18:01, 31 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://www.jexp.ru/index.php?title=Java/Database_SQL_JDBC/SQL_Update&amp;diff=7000&amp;oldid=prev"/>
				<updated>2010-05-31T18:01:44Z</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;== Batch Update ==&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;
/*&lt;br /&gt;
 * Copyright (c) 2006 Sun Microsystems, Inc. All Rights Reserved.&lt;br /&gt;
 *&lt;br /&gt;
 * Redistribution and use in source and binary forms, with or without&lt;br /&gt;
 * modification, are permitted provided that the following conditions are met:&lt;br /&gt;
 *&lt;br /&gt;
 * -Redistribution of source code must retain the above copyright notice, this&lt;br /&gt;
 *  list of conditions and the following disclaimer.&lt;br /&gt;
 *&lt;br /&gt;
 * -Redistribution in binary form must reproduce the above copyright notice,&lt;br /&gt;
 *  this list of conditions and the following disclaimer in the documentation&lt;br /&gt;
 *  and/or other materials provided with the distribution.&lt;br /&gt;
 *&lt;br /&gt;
 * Neither the name of Sun Microsystems, Inc. or the names of contributors may&lt;br /&gt;
 * be used to endorse or promote products derived from this software without&lt;br /&gt;
 * specific prior written permission.&lt;br /&gt;
 *&lt;br /&gt;
 * This software is provided &amp;quot;AS IS,&amp;quot; without a warranty of any kind. ALL&lt;br /&gt;
 * EXPRESS OR IMPLIED CONDITIONS, REPRESENTATIONS AND WARRANTIES, INCLUDING&lt;br /&gt;
 * ANY IMPLIED WARRANTY OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE&lt;br /&gt;
 * OR NON-INFRINGEMENT, ARE HEREBY EXCLUDED. SUN MIDROSYSTEMS, INC. (&amp;quot;SUN&amp;quot;)&lt;br /&gt;
 * AND ITS LICENSORS SHALL NOT BE LIABLE FOR ANY DAMAGES SUFFERED BY LICENSEE&lt;br /&gt;
 * AS A RESULT OF USING, MODIFYING OR DISTRIBUTING THIS SOFTWARE OR ITS&lt;br /&gt;
 * DERIVATIVES. IN NO EVENT WILL SUN OR ITS LICENSORS BE LIABLE FOR ANY LOST&lt;br /&gt;
 * REVENUE, PROFIT OR DATA, OR FOR DIRECT, INDIRECT, SPECIAL, CONSEQUENTIAL,&lt;br /&gt;
 * INCIDENTAL OR PUNITIVE DAMAGES, HOWEVER CAUSED AND REGARDLESS OF THE THEORY&lt;br /&gt;
 * OF LIABILITY, ARISING OUT OF THE USE OF OR INABILITY TO USE THIS SOFTWARE,&lt;br /&gt;
 * EVEN IF SUN HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.&lt;br /&gt;
 *&lt;br /&gt;
 * You acknowledge that this software is not designed, licensed or intended&lt;br /&gt;
 * for use in the design, construction, operation or maintenance of any&lt;br /&gt;
 * nuclear facility.&lt;br /&gt;
 */&lt;br /&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.ResultSet;&lt;br /&gt;
import java.sql.SQLException;&lt;br /&gt;
import java.sql.Statement;&lt;br /&gt;
public class BatchUpdate {&lt;br /&gt;
  public static void main(String args[]) {&lt;br /&gt;
    String url = &amp;quot;jdbc:mySubprotocol:myDataSource&amp;quot;;&lt;br /&gt;
    Connection con;&lt;br /&gt;
    Statement stmt;&lt;br /&gt;
    try {&lt;br /&gt;
      Class.forName(&amp;quot;myDriver.ClassName&amp;quot;);&lt;br /&gt;
    } catch (java.lang.ClassNotFoundException e) {&lt;br /&gt;
      System.err.print(&amp;quot;ClassNotFoundException: &amp;quot;);&lt;br /&gt;
      System.err.println(e.getMessage());&lt;br /&gt;
    }&lt;br /&gt;
    try {&lt;br /&gt;
      con = DriverManager.getConnection(url, &amp;quot;myLogin&amp;quot;, &amp;quot;myPassword&amp;quot;);&lt;br /&gt;
      stmt = con.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,&lt;br /&gt;
          ResultSet.CONCUR_UPDATABLE);&lt;br /&gt;
      con.setAutoCommit(false);&lt;br /&gt;
      stmt.addBatch(&amp;quot;INSERT INTO COFFEES &amp;quot;&lt;br /&gt;
          + &amp;quot;VALUES(&amp;quot;Amaretto&amp;quot;, 49, 9.99, 0, 0)&amp;quot;);&lt;br /&gt;
      stmt.addBatch(&amp;quot;INSERT INTO COFFEES &amp;quot;&lt;br /&gt;
          + &amp;quot;VALUES(&amp;quot;Hazelnut&amp;quot;, 49, 9.99, 0, 0)&amp;quot;);&lt;br /&gt;
      stmt.addBatch(&amp;quot;INSERT INTO COFFEES &amp;quot;&lt;br /&gt;
          + &amp;quot;VALUES(&amp;quot;Amaretto_decaf&amp;quot;, 49, 10.99, 0, 0)&amp;quot;);&lt;br /&gt;
      stmt.addBatch(&amp;quot;INSERT INTO COFFEES &amp;quot;&lt;br /&gt;
          + &amp;quot;VALUES(&amp;quot;Hazelnut_decaf&amp;quot;, 49, 10.99, 0, 0)&amp;quot;);&lt;br /&gt;
      int[] updateCounts = stmt.executeBatch();&lt;br /&gt;
      ResultSet uprs = stmt.executeQuery(&amp;quot;SELECT * FROM COFFEES&amp;quot;);&lt;br /&gt;
      System.out.println(&amp;quot;Table COFFEES after insertion:&amp;quot;);&lt;br /&gt;
      while (uprs.next()) {&lt;br /&gt;
        String name = uprs.getString(&amp;quot;COF_NAME&amp;quot;);&lt;br /&gt;
        int id = uprs.getInt(&amp;quot;SUP_ID&amp;quot;);&lt;br /&gt;
        float price = uprs.getFloat(&amp;quot;PRICE&amp;quot;);&lt;br /&gt;
        int sales = uprs.getInt(&amp;quot;SALES&amp;quot;);&lt;br /&gt;
        int total = uprs.getInt(&amp;quot;TOTAL&amp;quot;);&lt;br /&gt;
        System.out.print(name + &amp;quot; &amp;quot; + id + &amp;quot; &amp;quot; + price);&lt;br /&gt;
        System.out.println(&amp;quot; &amp;quot; + sales + &amp;quot; &amp;quot; + total);&lt;br /&gt;
      }&lt;br /&gt;
      uprs.close();&lt;br /&gt;
      stmt.close();&lt;br /&gt;
      con.close();&lt;br /&gt;
    } catch (BatchUpdateException b) {&lt;br /&gt;
      System.err.println(&amp;quot;SQLException: &amp;quot; + b.getMessage());&lt;br /&gt;
      System.err.println(&amp;quot;SQLState: &amp;quot; + b.getSQLState());&lt;br /&gt;
      System.err.println(&amp;quot;Message: &amp;quot; + b.getMessage());&lt;br /&gt;
      System.err.println(&amp;quot;Vendor: &amp;quot; + b.getErrorCode());&lt;br /&gt;
      System.err.print(&amp;quot;Update counts: &amp;quot;);&lt;br /&gt;
      int[] updateCounts = b.getUpdateCounts();&lt;br /&gt;
      for (int i = 0; i &amp;lt; updateCounts.length; i++) {&lt;br /&gt;
        System.err.print(updateCounts[i] + &amp;quot; &amp;quot;);&lt;br /&gt;
      }&lt;br /&gt;
    } catch (SQLException ex) {&lt;br /&gt;
      System.err.println(&amp;quot;SQLException: &amp;quot; + ex.getMessage());&lt;br /&gt;
      System.err.println(&amp;quot;SQLState: &amp;quot; + ex.getSQLState());&lt;br /&gt;
      System.err.println(&amp;quot;Message: &amp;quot; + ex.getMessage());&lt;br /&gt;
      System.err.println(&amp;quot;Vendor: &amp;quot; + ex.getErrorCode());&lt;br /&gt;
    }&lt;br /&gt;
  }&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;
== Batch Update: transaction ==&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;
/*&lt;br /&gt;
Copyright 2003 Sun Microsystems, Inc. ALL RIGHTS RESERVED.&lt;br /&gt;
Use of this software is authorized pursuant to the terms of the license found at&lt;br /&gt;
http://developer.java.sun.ru/berkeley_license.html.&lt;br /&gt;
Copyright 2003 Sun Microsystems, Inc. All Rights Reserved.  &lt;br /&gt;
Redistribution and use in source and binary forms, with or without modification,&lt;br /&gt;
are permitted provided that the following conditions are met: &lt;br /&gt;
- Redistribution of source code must retain the above copyright notice, &lt;br /&gt;
this list of conditions and the following disclaimer.&lt;br /&gt;
- Redistribution in binary form must reproduce the above copyright notice,&lt;br /&gt;
this list of conditions and the following disclaimer in the documentation&lt;br /&gt;
and/or other materials provided with the distribution.&lt;br /&gt;
Neither the name of Sun Microsystems, Inc. or the names of contributors may &lt;br /&gt;
be used to endorse or promote products derived from this software without&lt;br /&gt;
specific prior written permission.&lt;br /&gt;
This software is provided &amp;quot;AS IS,&amp;quot; without a warranty of any kind.  &lt;br /&gt;
ALL EXPRESS OR IMPLIED CONDITIONS, REPRESENTATIONS AND WARRANTIES, INCLUDING&lt;br /&gt;
ANY IMPLIED WARRANTY OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR&lt;br /&gt;
NON-INFRINGEMENT, ARE HEREBY EXCLUDED. SUN MICORSYSTEMS, INC. (&amp;quot;SUN&amp;quot;)&lt;br /&gt;
AND ITS LICENSORS SHALL NOT BE LIABLE FOR ANY DAMAGES SUFFERED BY LICENSEE&lt;br /&gt;
AS A RESULT OF USING, MODIFYING OR DISTRIBUTING THIS SOFTWARE OR ITS&lt;br /&gt;
DERIVATIVES. IN NO EVENT WILL SUN OR ITS LICENSORS BE LIABLE FOR ANY LOST&lt;br /&gt;
REVENUE, PROFIT OR DATA, OR FOR DIRECT, INDIRECT, SPECIAL, CONSEQUENTIAL, &lt;br /&gt;
INCIDENTAL OR PUNITIVE DAMAGES, HOWEVER CAUSED AND REGARDLESS OF THE THEORY OF&lt;br /&gt;
LIABILITY, ARISING OUT OF THE USE OF OR INABILITY TO USE THIS SOFTWARE, EVEN&lt;br /&gt;
IF SUN HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.&lt;br /&gt;
You acknowledge that this software is not designed, licensed or intended for&lt;br /&gt;
use in the design, construction, operation or maintenance of any nuclear&lt;br /&gt;
facility.&lt;br /&gt;
&lt;br /&gt;
*/&lt;br /&gt;
/*&lt;br /&gt;
 * Copyright 2003 Sun Microsystems, Inc.  ALL RIGHTS RESERVED.&lt;br /&gt;
 * Use of this software is authorized pursuant to the terms of the license found at&lt;br /&gt;
 * http://developer.java.sun.ru/berkeley_license.html.&lt;br /&gt;
 */ &lt;br /&gt;
import java.sql.*;&lt;br /&gt;
public class BatchUpdate {&lt;br /&gt;
  public static void main(String args[]) throws SQLException {&lt;br /&gt;
    ResultSet rs = null;&lt;br /&gt;
    PreparedStatement ps = null;&lt;br /&gt;
    String url = &amp;quot;jdbc:mySubprotocol:myDataSource&amp;quot;;&lt;br /&gt;
    Connection con;&lt;br /&gt;
    Statement stmt;&lt;br /&gt;
    try {&lt;br /&gt;
      Class.forName(&amp;quot;myDriver.ClassName&amp;quot;);&lt;br /&gt;
    } catch(java.lang.ClassNotFoundException e) {&lt;br /&gt;
      System.err.print(&amp;quot;ClassNotFoundException: &amp;quot;);&lt;br /&gt;
      System.err.println(e.getMessage());&lt;br /&gt;
    }&lt;br /&gt;
    try {&lt;br /&gt;
      con = DriverManager.getConnection(url,&lt;br /&gt;
                  &amp;quot;myLogin&amp;quot;, &amp;quot;myPassword&amp;quot;);&lt;br /&gt;
      con.setAutoCommit(false);&lt;br /&gt;
      stmt = con.createStatement();  &lt;br /&gt;
      stmt.addBatch(&amp;quot;INSERT INTO COFFEES &amp;quot; + &lt;br /&gt;
         &amp;quot;VALUES(&amp;quot;Amaretto&amp;quot;, 49, 9.99, 0, 0)&amp;quot;);&lt;br /&gt;
      stmt.addBatch(&amp;quot;INSERT INTO COFFEES &amp;quot; +&lt;br /&gt;
        &amp;quot;VALUES(&amp;quot;Hazelnut&amp;quot;, 49, 9.99, 0, 0)&amp;quot;);&lt;br /&gt;
      stmt.addBatch(&amp;quot;INSERT INTO COFFEES &amp;quot; +&lt;br /&gt;
        &amp;quot;VALUES(&amp;quot;Amaretto_decaf&amp;quot;, 49, 10.99, 0, 0)&amp;quot;);&lt;br /&gt;
      stmt.addBatch(&amp;quot;INSERT INTO COFFEES &amp;quot; +&lt;br /&gt;
        &amp;quot;VALUES(&amp;quot;Hazelnut_decaf&amp;quot;, 49, 10.99, 0, 0)&amp;quot;);&lt;br /&gt;
      int [] updateCounts = stmt.executeBatch();&lt;br /&gt;
      con.rumit();&lt;br /&gt;
      con.setAutoCommit(true);&lt;br /&gt;
      ResultSet uprs = stmt.executeQuery(&amp;quot;SELECT * FROM COFFEES&amp;quot;);&lt;br /&gt;
      System.out.println(&amp;quot;Table COFFEES after insertion:&amp;quot;);&lt;br /&gt;
      while (uprs.next()) {&lt;br /&gt;
        String name = uprs.getString(&amp;quot;COF_NAME&amp;quot;);&lt;br /&gt;
        int id = uprs.getInt(&amp;quot;SUP_ID&amp;quot;);&lt;br /&gt;
        float price = uprs.getFloat(&amp;quot;PRICE&amp;quot;);&lt;br /&gt;
        int sales = uprs.getInt(&amp;quot;SALES&amp;quot;);&lt;br /&gt;
        int total = uprs.getInt(&amp;quot;TOTAL&amp;quot;);&lt;br /&gt;
        System.out.print(name + &amp;quot;   &amp;quot; + id + &amp;quot;   &amp;quot; + price);&lt;br /&gt;
        System.out.println(&amp;quot;   &amp;quot; + sales + &amp;quot;   &amp;quot; + total);&lt;br /&gt;
      }&lt;br /&gt;
      uprs.close();&lt;br /&gt;
      stmt.close();&lt;br /&gt;
      con.close();&lt;br /&gt;
    } catch(BatchUpdateException b) {&lt;br /&gt;
      System.err.println(&amp;quot;-----BatchUpdateException-----&amp;quot;);&lt;br /&gt;
      System.err.println(&amp;quot;SQLState:  &amp;quot; + b.getSQLState());&lt;br /&gt;
      System.err.println(&amp;quot;Message:  &amp;quot; + b.getMessage());&lt;br /&gt;
      System.err.println(&amp;quot;Vendor:  &amp;quot; + b.getErrorCode());&lt;br /&gt;
      System.err.print(&amp;quot;Update counts:  &amp;quot;);&lt;br /&gt;
      int [] updateCounts = b.getUpdateCounts();&lt;br /&gt;
      for (int i = 0; i &amp;lt; updateCounts.length; i++) {&lt;br /&gt;
        System.err.print(updateCounts[i] + &amp;quot;   &amp;quot;);&lt;br /&gt;
      }&lt;br /&gt;
      System.err.println(&amp;quot;&amp;quot;);&lt;br /&gt;
    } catch(SQLException ex) {&lt;br /&gt;
      System.err.println(&amp;quot;-----SQLException-----&amp;quot;);&lt;br /&gt;
      System.err.println(&amp;quot;SQLState:  &amp;quot; + ex.getSQLState());&lt;br /&gt;
      System.err.println(&amp;quot;Message:  &amp;quot; + ex.getMessage());&lt;br /&gt;
      System.err.println(&amp;quot;Vendor:  &amp;quot; + ex.getErrorCode());&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;/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;
== Create Coffees table ==&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;
/*&lt;br /&gt;
 * Copyright (c) 2006 Sun Microsystems, Inc. All Rights Reserved.&lt;br /&gt;
 *&lt;br /&gt;
 * Redistribution and use in source and binary forms, with or without&lt;br /&gt;
 * modification, are permitted provided that the following conditions are met:&lt;br /&gt;
 *&lt;br /&gt;
 * -Redistribution of source code must retain the above copyright notice, this&lt;br /&gt;
 *  list of conditions and the following disclaimer.&lt;br /&gt;
 *&lt;br /&gt;
 * -Redistribution in binary form must reproduce the above copyright notice,&lt;br /&gt;
 *  this list of conditions and the following disclaimer in the documentation&lt;br /&gt;
 *  and/or other materials provided with the distribution.&lt;br /&gt;
 *&lt;br /&gt;
 * Neither the name of Sun Microsystems, Inc. or the names of contributors may&lt;br /&gt;
 * be used to endorse or promote products derived from this software without&lt;br /&gt;
 * specific prior written permission.&lt;br /&gt;
 *&lt;br /&gt;
 * This software is provided &amp;quot;AS IS,&amp;quot; without a warranty of any kind. ALL&lt;br /&gt;
 * EXPRESS OR IMPLIED CONDITIONS, REPRESENTATIONS AND WARRANTIES, INCLUDING&lt;br /&gt;
 * ANY IMPLIED WARRANTY OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE&lt;br /&gt;
 * OR NON-INFRINGEMENT, ARE HEREBY EXCLUDED. SUN MIDROSYSTEMS, INC. (&amp;quot;SUN&amp;quot;)&lt;br /&gt;
 * AND ITS LICENSORS SHALL NOT BE LIABLE FOR ANY DAMAGES SUFFERED BY LICENSEE&lt;br /&gt;
 * AS A RESULT OF USING, MODIFYING OR DISTRIBUTING THIS SOFTWARE OR ITS&lt;br /&gt;
 * DERIVATIVES. IN NO EVENT WILL SUN OR ITS LICENSORS BE LIABLE FOR ANY LOST&lt;br /&gt;
 * REVENUE, PROFIT OR DATA, OR FOR DIRECT, INDIRECT, SPECIAL, CONSEQUENTIAL,&lt;br /&gt;
 * INCIDENTAL OR PUNITIVE DAMAGES, HOWEVER CAUSED AND REGARDLESS OF THE THEORY&lt;br /&gt;
 * OF LIABILITY, ARISING OUT OF THE USE OF OR INABILITY TO USE THIS SOFTWARE,&lt;br /&gt;
 * EVEN IF SUN HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.&lt;br /&gt;
 *&lt;br /&gt;
 * You acknowledge that this software is not designed, licensed or intended&lt;br /&gt;
 * for use in the design, construction, operation or maintenance of any&lt;br /&gt;
 * nuclear facility.&lt;br /&gt;
 */&lt;br /&gt;
&lt;br /&gt;
import java.sql.Connection;&lt;br /&gt;
import java.sql.DriverManager;&lt;br /&gt;
import java.sql.SQLException;&lt;br /&gt;
import java.sql.Statement;&lt;br /&gt;
public class CreateCoffees {&lt;br /&gt;
  public static void main(String args[]) {&lt;br /&gt;
    String url = &amp;quot;jdbc:mySubprotocol:myDataSource&amp;quot;;&lt;br /&gt;
    Connection con;&lt;br /&gt;
    String createString;&lt;br /&gt;
    createString = &amp;quot;create table COFFEES &amp;quot; + &amp;quot;(COF_NAME VARCHAR(32), &amp;quot;&lt;br /&gt;
        + &amp;quot;SUP_ID INTEGER, &amp;quot; + &amp;quot;PRICE FLOAT, &amp;quot; + &amp;quot;SALES INTEGER, &amp;quot;&lt;br /&gt;
        + &amp;quot;TOTAL INTEGER)&amp;quot;;&lt;br /&gt;
    Statement stmt;&lt;br /&gt;
    try {&lt;br /&gt;
      Class.forName(&amp;quot;myDriver.ClassName&amp;quot;);&lt;br /&gt;
    } catch (java.lang.ClassNotFoundException e) {&lt;br /&gt;
      System.err.print(&amp;quot;ClassNotFoundException: &amp;quot;);&lt;br /&gt;
      System.err.println(e.getMessage());&lt;br /&gt;
    }&lt;br /&gt;
    try {&lt;br /&gt;
      con = DriverManager.getConnection(url, &amp;quot;myLogin&amp;quot;, &amp;quot;myPassword&amp;quot;);&lt;br /&gt;
      stmt = con.createStatement();&lt;br /&gt;
      stmt.executeUpdate(createString);&lt;br /&gt;
      stmt.close();&lt;br /&gt;
      con.close();&lt;br /&gt;
    } catch (SQLException ex) {&lt;br /&gt;
      System.err.println(&amp;quot;SQLException: &amp;quot; + ex.getMessage());&lt;br /&gt;
    }&lt;br /&gt;
  }&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;
== Get Metadata from prepareStatement ==&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;
/*&lt;br /&gt;
Copyright 2003 Sun Microsystems, Inc. ALL RIGHTS RESERVED.&lt;br /&gt;
Use of this software is authorized pursuant to the terms of the license found at&lt;br /&gt;
http://developer.java.sun.ru/berkeley_license.html.&lt;br /&gt;
Copyright 2003 Sun Microsystems, Inc. All Rights Reserved.  &lt;br /&gt;
Redistribution and use in source and binary forms, with or without modification,&lt;br /&gt;
are permitted provided that the following conditions are met: &lt;br /&gt;
- Redistribution of source code must retain the above copyright notice, &lt;br /&gt;
this list of conditions and the following disclaimer.&lt;br /&gt;
- Redistribution in binary form must reproduce the above copyright notice,&lt;br /&gt;
this list of conditions and the following disclaimer in the documentation&lt;br /&gt;
and/or other materials provided with the distribution.&lt;br /&gt;
Neither the name of Sun Microsystems, Inc. or the names of contributors may &lt;br /&gt;
be used to endorse or promote products derived from this software without&lt;br /&gt;
specific prior written permission.&lt;br /&gt;
This software is provided &amp;quot;AS IS,&amp;quot; without a warranty of any kind.  &lt;br /&gt;
ALL EXPRESS OR IMPLIED CONDITIONS, REPRESENTATIONS AND WARRANTIES, INCLUDING&lt;br /&gt;
ANY IMPLIED WARRANTY OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR&lt;br /&gt;
NON-INFRINGEMENT, ARE HEREBY EXCLUDED. SUN MICORSYSTEMS, INC. (&amp;quot;SUN&amp;quot;)&lt;br /&gt;
AND ITS LICENSORS SHALL NOT BE LIABLE FOR ANY DAMAGES SUFFERED BY LICENSEE&lt;br /&gt;
AS A RESULT OF USING, MODIFYING OR DISTRIBUTING THIS SOFTWARE OR ITS&lt;br /&gt;
DERIVATIVES. IN NO EVENT WILL SUN OR ITS LICENSORS BE LIABLE FOR ANY LOST&lt;br /&gt;
REVENUE, PROFIT OR DATA, OR FOR DIRECT, INDIRECT, SPECIAL, CONSEQUENTIAL, &lt;br /&gt;
INCIDENTAL OR PUNITIVE DAMAGES, HOWEVER CAUSED AND REGARDLESS OF THE THEORY OF&lt;br /&gt;
LIABILITY, ARISING OUT OF THE USE OF OR INABILITY TO USE THIS SOFTWARE, EVEN&lt;br /&gt;
IF SUN HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.&lt;br /&gt;
You acknowledge that this software is not designed, licensed or intended for&lt;br /&gt;
use in the design, construction, operation or maintenance of any nuclear&lt;br /&gt;
facility.&lt;br /&gt;
&lt;br /&gt;
*/&lt;br /&gt;
&lt;br /&gt;
/*&lt;br /&gt;
 * Copyright 2003 Sun Microsystems, Inc.  ALL RIGHTS RESERVED.&lt;br /&gt;
 * Use of this software is authorized pursuant to the terms of the license found at&lt;br /&gt;
 * http://developer.java.sun.ru/berkeley_license.html.&lt;br /&gt;
 */ &lt;br /&gt;
import java.sql.*;&lt;br /&gt;
public class GetParamMetaData {&lt;br /&gt;
    public static void main(String args[]) {&lt;br /&gt;
    String url = &amp;quot;jdbc:mySubprotocol:myDataSource&amp;quot;;&lt;br /&gt;
    Connection con;&lt;br /&gt;
    PreparedStatement pstmt;&lt;br /&gt;
    ParameterMetaData pmd;&lt;br /&gt;
    String sql = &amp;quot;UPDATE COFFEES SET SALES = ? &amp;quot; +&lt;br /&gt;
                      &amp;quot;WHERE COF_NAME = ?&amp;quot;;&lt;br /&gt;
    try {&lt;br /&gt;
      Class.forName(&amp;quot;myDriver.ClassName&amp;quot;);&lt;br /&gt;
    } catch(java.lang.ClassNotFoundException e) {&lt;br /&gt;
          System.err.print(&amp;quot;ClassNotFoundException: &amp;quot;);&lt;br /&gt;
        System.err.println(e.getMessage());&lt;br /&gt;
    }&lt;br /&gt;
    try {&lt;br /&gt;
        con = DriverManager.getConnection(url,&lt;br /&gt;
            &amp;quot;myLogin&amp;quot;, &amp;quot;myPassword&amp;quot;);&lt;br /&gt;
      pstmt = con.prepareStatement(sql);&lt;br /&gt;
      pmd = pstmt.getParameterMetaData();&lt;br /&gt;
      int totalDigits = pmd.getPrecision(1);&lt;br /&gt;
      int digitsAfterDecimal = pmd.getScale(1);&lt;br /&gt;
      boolean b = pmd.isSigned(1);&lt;br /&gt;
      System.out.println(&amp;quot;The first parameter &amp;quot;);&lt;br /&gt;
      System.out.println(&amp;quot;    has precision &amp;quot; + totalDigits);&lt;br /&gt;
      System.out.println(&amp;quot;    has scale &amp;quot; + digitsAfterDecimal);&lt;br /&gt;
      System.out.println(&amp;quot;    may be a signed number &amp;quot; + b);&lt;br /&gt;
      int count = pmd.getParameterCount();&lt;br /&gt;
      System.out.println(&amp;quot;count is &amp;quot; + count);&lt;br /&gt;
      for (int i = 1; i &amp;lt;= count; i++) {&lt;br /&gt;
        int type = pmd.getParameterType(i);&lt;br /&gt;
        String typeName = pmd.getParameterTypeName(i);&lt;br /&gt;
        System.out.println(&amp;quot;Parameter &amp;quot; + i + &amp;quot;:&amp;quot;); &lt;br /&gt;
        System.out.println(&amp;quot;    type is &amp;quot; + type); &lt;br /&gt;
        System.out.println(&amp;quot;    type name is &amp;quot; + typeName); &lt;br /&gt;
      }&lt;br /&gt;
        &lt;br /&gt;
      pstmt.close();&lt;br /&gt;
         con.close();&lt;br /&gt;
        } catch (Exception e) {&lt;br /&gt;
      e.printStackTrace();&lt;br /&gt;
    }&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
&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;
== JDBC update ==&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;
/*&lt;br /&gt;
Database Programming with JDBC and Java, Second Edition&lt;br /&gt;
By George Reese&lt;br /&gt;
ISBN: 1-56592-616-1&lt;br /&gt;
Publisher: O&amp;quot;Reilly&lt;br /&gt;
*/&lt;br /&gt;
&lt;br /&gt;
import java.sql.Connection;&lt;br /&gt;
import java.sql.DriverManager;&lt;br /&gt;
import java.sql.SQLException;&lt;br /&gt;
import java.sql.Statement;&lt;br /&gt;
/**&lt;br /&gt;
 * Example 3.3&lt;br /&gt;
 */&lt;br /&gt;
public class Update {&lt;br /&gt;
  public static void main(String args[]) {&lt;br /&gt;
    Connection con = null;&lt;br /&gt;
    if (args.length != 2) {&lt;br /&gt;
      System.out.println(&amp;quot;Syntax: &amp;lt;java UpdateApp [number] [string]&amp;gt;&amp;quot;);&lt;br /&gt;
      return;&lt;br /&gt;
    }&lt;br /&gt;
    try {&lt;br /&gt;
      String driver = &amp;quot;com.imaginary.sql.msql.MsqlDriver&amp;quot;;&lt;br /&gt;
      Class.forName(driver).newInstance();&lt;br /&gt;
      String url = &amp;quot;jdbc:msql://carthage.imaginary.ru/ora&amp;quot;;&lt;br /&gt;
      con = DriverManager.getConnection(url, &amp;quot;borg&amp;quot;, &amp;quot;&amp;quot;);&lt;br /&gt;
      Statement s = con.createStatement();&lt;br /&gt;
      String test_id = args[0];&lt;br /&gt;
      String test_val = args[1];&lt;br /&gt;
      int update_count = s&lt;br /&gt;
          .executeUpdate(&amp;quot;INSERT INTO test (test_id, test_val) &amp;quot;&lt;br /&gt;
              + &amp;quot;VALUES(&amp;quot; + test_id + &amp;quot;, &amp;quot;&amp;quot; + test_val + &amp;quot;&amp;quot;)&amp;quot;);&lt;br /&gt;
      System.out.println(update_count + &amp;quot; rows inserted.&amp;quot;);&lt;br /&gt;
      s.close();&lt;br /&gt;
    } catch (Exception e) {&lt;br /&gt;
      e.printStackTrace();&lt;br /&gt;
    } finally {&lt;br /&gt;
      if (con != null) {&lt;br /&gt;
        try {&lt;br /&gt;
          con.close();&lt;br /&gt;
        } catch (SQLException e) {&lt;br /&gt;
          e.printStackTrace();&lt;br /&gt;
        }&lt;br /&gt;
      }&lt;br /&gt;
    }&lt;br /&gt;
  }&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;
== JDBC Update logic ==&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;
/*&lt;br /&gt;
Database Programming with JDBC and Java, Second Edition&lt;br /&gt;
By George Reese&lt;br /&gt;
ISBN: 1-56592-616-1&lt;br /&gt;
Publisher: O&amp;quot;Reilly&lt;br /&gt;
*/&lt;br /&gt;
&lt;br /&gt;
import java.sql.Connection;&lt;br /&gt;
import java.sql.DriverManager;&lt;br /&gt;
import java.sql.SQLException;&lt;br /&gt;
import java.sql.Statement;&lt;br /&gt;
/**&lt;br /&gt;
 * Example 3.4.&lt;br /&gt;
 */&lt;br /&gt;
public class UpdateLogic {&lt;br /&gt;
  public static void main(String args[]) {&lt;br /&gt;
    Connection con = null;&lt;br /&gt;
    if (args.length != 2) {&lt;br /&gt;
      System.out.println(&amp;quot;Syntax: &amp;lt;java UpdateLogic [number] [string]&amp;gt;&amp;quot;);&lt;br /&gt;
      return;&lt;br /&gt;
    }&lt;br /&gt;
    try {&lt;br /&gt;
      String driver = &amp;quot;com.imaginary.sql.msql.MsqlDriver&amp;quot;;&lt;br /&gt;
      Class.forName(driver).newInstance();&lt;br /&gt;
      String url = &amp;quot;jdbc:msql://carthage.imaginary.ru/ora&amp;quot;;&lt;br /&gt;
      Statement s;&lt;br /&gt;
      con = DriverManager.getConnection(url, &amp;quot;borg&amp;quot;, &amp;quot;&amp;quot;);&lt;br /&gt;
      con.setAutoCommit(false); // make sure auto commit is off!&lt;br /&gt;
      s = con.createStatement();// create the first statement&lt;br /&gt;
      s.executeUpdate(&amp;quot;INSERT INTO test (test_id, test_val) &amp;quot; + &amp;quot;VALUES(&amp;quot;&lt;br /&gt;
          + args[0] + &amp;quot;, &amp;quot;&amp;quot; + args[1] + &amp;quot;&amp;quot;)&amp;quot;);&lt;br /&gt;
      s.close(); // close the first statement&lt;br /&gt;
      s = con.createStatement(); // create the second statement&lt;br /&gt;
      s.executeUpdate(&amp;quot;INSERT into test_desc (test_id, test_desc) &amp;quot;&lt;br /&gt;
          + &amp;quot;VALUES(&amp;quot; + args[0] + &amp;quot;, &amp;quot;This describes the test.&amp;quot;)&amp;quot;);&lt;br /&gt;
      con.rumit(); // commit the two statements&lt;br /&gt;
      System.out.println(&amp;quot;Insert succeeded.&amp;quot;);&lt;br /&gt;
      s.close(); // close the second statement&lt;br /&gt;
    } catch (Exception e) {&lt;br /&gt;
      if (con != null) {&lt;br /&gt;
        try {&lt;br /&gt;
          con.rollback();&lt;br /&gt;
        } // rollback on error&lt;br /&gt;
        catch (SQLException e2) {&lt;br /&gt;
        }&lt;br /&gt;
      }&lt;br /&gt;
      e.printStackTrace();&lt;br /&gt;
    } finally {&lt;br /&gt;
      if (con != null) {&lt;br /&gt;
        try {&lt;br /&gt;
          con.close();&lt;br /&gt;
        } catch (SQLException e) {&lt;br /&gt;
          e.printStackTrace();&lt;br /&gt;
        }&lt;br /&gt;
      }&lt;br /&gt;
    }&lt;br /&gt;
  }&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;
== Return generated keys ==&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;
/*&lt;br /&gt;
Copyright 2003 Sun Microsystems, Inc. ALL RIGHTS RESERVED.&lt;br /&gt;
Use of this software is authorized pursuant to the terms of the license found at&lt;br /&gt;
http://developer.java.sun.ru/berkeley_license.html.&lt;br /&gt;
Copyright 2003 Sun Microsystems, Inc. All Rights Reserved.  &lt;br /&gt;
Redistribution and use in source and binary forms, with or without modification,&lt;br /&gt;
are permitted provided that the following conditions are met: &lt;br /&gt;
- Redistribution of source code must retain the above copyright notice, &lt;br /&gt;
this list of conditions and the following disclaimer.&lt;br /&gt;
- Redistribution in binary form must reproduce the above copyright notice,&lt;br /&gt;
this list of conditions and the following disclaimer in the documentation&lt;br /&gt;
and/or other materials provided with the distribution.&lt;br /&gt;
Neither the name of Sun Microsystems, Inc. or the names of contributors may &lt;br /&gt;
be used to endorse or promote products derived from this software without&lt;br /&gt;
specific prior written permission.&lt;br /&gt;
This software is provided &amp;quot;AS IS,&amp;quot; without a warranty of any kind.  &lt;br /&gt;
ALL EXPRESS OR IMPLIED CONDITIONS, REPRESENTATIONS AND WARRANTIES, INCLUDING&lt;br /&gt;
ANY IMPLIED WARRANTY OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR&lt;br /&gt;
NON-INFRINGEMENT, ARE HEREBY EXCLUDED. SUN MICORSYSTEMS, INC. (&amp;quot;SUN&amp;quot;)&lt;br /&gt;
AND ITS LICENSORS SHALL NOT BE LIABLE FOR ANY DAMAGES SUFFERED BY LICENSEE&lt;br /&gt;
AS A RESULT OF USING, MODIFYING OR DISTRIBUTING THIS SOFTWARE OR ITS&lt;br /&gt;
DERIVATIVES. IN NO EVENT WILL SUN OR ITS LICENSORS BE LIABLE FOR ANY LOST&lt;br /&gt;
REVENUE, PROFIT OR DATA, OR FOR DIRECT, INDIRECT, SPECIAL, CONSEQUENTIAL, &lt;br /&gt;
INCIDENTAL OR PUNITIVE DAMAGES, HOWEVER CAUSED AND REGARDLESS OF THE THEORY OF&lt;br /&gt;
LIABILITY, ARISING OUT OF THE USE OF OR INABILITY TO USE THIS SOFTWARE, EVEN&lt;br /&gt;
IF SUN HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.&lt;br /&gt;
You acknowledge that this software is not designed, licensed or intended for&lt;br /&gt;
use in the design, construction, operation or maintenance of any nuclear&lt;br /&gt;
facility.&lt;br /&gt;
&lt;br /&gt;
*/&lt;br /&gt;
/*&lt;br /&gt;
 * Copyright 2003 Sun Microsystems, Inc.  ALL RIGHTS RESERVED.&lt;br /&gt;
 * Use of this software is authorized pursuant to the terms of the license found at&lt;br /&gt;
 * http://developer.java.sun.ru/berkeley_license.html.&lt;br /&gt;
 */ &lt;br /&gt;
import java.sql.*;&lt;br /&gt;
public class AutoGenKeys {&lt;br /&gt;
    public static void main(String args[]) {&lt;br /&gt;
        String url = &amp;quot;jdbc:mySubprotocol:myDataSource&amp;quot;;&lt;br /&gt;
    Connection con = null;&lt;br /&gt;
    PreparedStatement pstmt;&lt;br /&gt;
    String insert = &amp;quot;INSERT INTO COFFEES VALUES (&amp;quot;HYPER_BLEND&amp;quot;, &amp;quot; +&lt;br /&gt;
                      &amp;quot;101, 10.99, 0, 0)&amp;quot;;&lt;br /&gt;
    String update = &amp;quot;UPDATE COFFEES SET PRICE = ? WHERE KEY = ?&amp;quot;;&lt;br /&gt;
    try {&lt;br /&gt;
      Class.forName(&amp;quot;myDriver.ClassName&amp;quot;);&lt;br /&gt;
    } catch(java.lang.ClassNotFoundException e) {&lt;br /&gt;
          System.err.print(&amp;quot;ClassNotFoundException: &amp;quot;);&lt;br /&gt;
        System.err.println(e.getMessage());&lt;br /&gt;
    }&lt;br /&gt;
    try {&lt;br /&gt;
        con = DriverManager.getConnection(url,&lt;br /&gt;
            &amp;quot;myLogin&amp;quot;, &amp;quot;myPassword&amp;quot;);&lt;br /&gt;
      pstmt = con.prepareStatement(insert,&lt;br /&gt;
          Statement.RETURN_GENERATED_KEYS);&lt;br /&gt;
      pstmt.executeUpdate();&lt;br /&gt;
      ResultSet keys = pstmt.getGeneratedKeys();&lt;br /&gt;
      int count = 0;&lt;br /&gt;
      &lt;br /&gt;
      keys.next();&lt;br /&gt;
      int key = keys.getInt(1);&lt;br /&gt;
      pstmt = con.prepareStatement(update);&lt;br /&gt;
      pstmt.setFloat(1, 11.99f);&lt;br /&gt;
      pstmt.setInt(2, key);&lt;br /&gt;
      pstmt.executeUpdate();&lt;br /&gt;
      keys.close();&lt;br /&gt;
      pstmt.close();&lt;br /&gt;
         con.close();&lt;br /&gt;
    } catch (SQLException e) {&lt;br /&gt;
        e.printStackTrace();&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;/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;
== SQL Batch  ==&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;
/*&lt;br /&gt;
Database Programming with JDBC and Java, Second Edition&lt;br /&gt;
By George Reese&lt;br /&gt;
ISBN: 1-56592-616-1&lt;br /&gt;
Publisher: O&amp;quot;Reilly&lt;br /&gt;
*/&lt;br /&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.util.ArrayList;&lt;br /&gt;
import java.util.Iterator;&lt;br /&gt;
/**&lt;br /&gt;
 * Example 4.1.&lt;br /&gt;
 */&lt;br /&gt;
public class Batch {&lt;br /&gt;
  static public void main(String[] args) {&lt;br /&gt;
    Connection conn = null;&lt;br /&gt;
    try {&lt;br /&gt;
      ArrayList breakable = new ArrayList();&lt;br /&gt;
      PreparedStatement stmt;&lt;br /&gt;
      Iterator users;&lt;br /&gt;
      ResultSet rs;&lt;br /&gt;
      Class.forName(args[0]).newInstance();&lt;br /&gt;
      conn = DriverManager.getConnection(args[1], args[2], args[3]);&lt;br /&gt;
      stmt = conn.prepareStatement(&amp;quot;SELECT user_id, password &amp;quot;&lt;br /&gt;
          + &amp;quot;FROM user&amp;quot;);&lt;br /&gt;
      rs = stmt.executeQuery();&lt;br /&gt;
      while (rs.next()) {&lt;br /&gt;
        String uid = rs.getString(1);&lt;br /&gt;
        String pw = rs.getString(2);&lt;br /&gt;
        // Assume PasswordCracker is some class that provides&lt;br /&gt;
        // a single static method called crack() that attempts&lt;br /&gt;
        // to run password cracking routines on the password&lt;br /&gt;
        //                if( PasswordCracker.crack(uid, pw) ) {&lt;br /&gt;
        //                  breakable.add(uid);&lt;br /&gt;
        //            }&lt;br /&gt;
      }&lt;br /&gt;
      stmt.close();&lt;br /&gt;
      if (breakable.size() &amp;lt; 1) {&lt;br /&gt;
        return;&lt;br /&gt;
      }&lt;br /&gt;
      stmt = conn.prepareStatement(&amp;quot;UPDATE user &amp;quot;&lt;br /&gt;
          + &amp;quot;SET bad_password = &amp;quot;Y&amp;quot; &amp;quot; + &amp;quot;WHERE uid = ?&amp;quot;);&lt;br /&gt;
      users = breakable.iterator();&lt;br /&gt;
      while (users.hasNext()) {&lt;br /&gt;
        String uid = (String) users.next();&lt;br /&gt;
        stmt.setString(1, uid);&lt;br /&gt;
        stmt.addBatch();&lt;br /&gt;
      }&lt;br /&gt;
      stmt.executeBatch();&lt;br /&gt;
    } catch (Exception e) {&lt;br /&gt;
      e.printStackTrace();&lt;br /&gt;
    } finally {&lt;br /&gt;
      if (conn != null) {&lt;br /&gt;
        try {&lt;br /&gt;
          conn.close();&lt;br /&gt;
        } catch (Exception e) {&lt;br /&gt;
        }&lt;br /&gt;
      }&lt;br /&gt;
    }&lt;br /&gt;
  }&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;/div&gt;</summary>
			</entry>

	</feed>