java left logo
java middle logo
java right logo
 

Home arrow Other API Tips
 
 
Main Menu
Home
Java Tutorials
Book Reviews
Java SE Tips
Java ME Tips
Java EE Tips
Other API Tips
Java Applications
Java Libraries
Java Games
Java Network
Java Forums
Java Blog




Most Visited Tips
Java SE Tips
Java ME Tips
Java EE Tips
Other API Tips
Java Applications
Java Libraries
Java Games
Book Reviews
Top Rated Tips
Java SE Tips
Java ME Tips
Java EE Tips
Other API Tips
Java Applications
Java Libraries
Java Games
Book Reviews


Statistics
Registered Users: 4088
Java SE Tips: 614
Java ME Tips: 202
Java EE Tips: 183
Other API Tips: 779
Java Applications: 298
Java Libraries: 209
Java Games: 16
Book Reviews:
 
 
 
How to exceute a batch process from PreparedStatement E-mail
User Rating: / 45
PoorBest 

PreparedStatement represents precompiled SQL statement that can be used mulitple times by setting parameters to this object. In order to successfully execute Batch in a database, it is advised to keep autocommit flag OFF and commit the transaction after Batch is executed.

The example below executes Batch of SQL statement from PreparedStatement object. Commented line executes Successfully, but the line with comment throws BatchUpdateException and points out the error in a particular transaction.

import java.sql.*;

public class testPrepareBatch 
{
    public static void main(String[] args
    {
        DB db = new DB();
        Connection conn=db.dbConnect(
    "jdbc:jtds:sqlserver://localhost:1433/tempdb","sa","");
        db.performBatch(conn);
    }
}

class DB
{
    public DB() {}

    public Connection dbConnect(String db_connect_string,
  String db_userid, String db_password)
    {
        try
        {
            Class.forName("net.sourceforge.jtds.jdbc.Driver");
            Connection conn = DriverManager.getConnection(
    db_connect_string, db_userid, db_password);
            System.out.println("connected");
            return conn;
            
        }
        catch (Exception e)
        {
            e.printStackTrace();
            return null;
        }
    }

    public void performBatch(Connection conn)
    {
        String query;
        PreparedStatement stmt;
                Statement st;
        
        try
        {
            conn.setAutoCommit(false);

            stmt = conn.prepareStatement(
    "insert into customer (name,category,age) values (?,?,?)");  
                        stmt.clearParameters();
                        stmt.setString(1,"name2");
                        stmt.setString(2,"cat2");
                        stmt.setInt(3,25);
                        stmt.addBatch();
                        stmt.clearParameters();
                        stmt.setString(1,"name3");
                        stmt.setString(2,"cat3");
                        stmt.setInt(3,25);
                        stmt.addBatch();
                        stmt.clearParameters();
                        stmt.setString(1,"name4");
                        stmt.setString(2,"cat2");
                        stmt.setInt(3,25);
                        stmt.addBatch();
                        stmt.clearParameters();
                        stmt.setString(1,"name4");
                        stmt.setString(2,"cat2");
                        //stmt.setInt(3,25);
      
      //this is parameter with false input
                        stmt.setString(3,"null")
                        
      stmt.addBatch();
                        stmt.clearParameters();
                        stmt.setString(1,"name5");
                        stmt.setString(2,"cat5");
                        stmt.setInt(3,25);
                        stmt.addBatch();
                        stmt.clearParameters();
        
            int [] updateCounts = stmt.executeBatch();
            conn.commit();
            conn.setAutoCommit(true);

                        stmt.close();
            conn.close();

        }
                catch(BatchUpdateException b
                {
                        System.err.println("-----BatchUpdateException-----");
                        System.err.println("SQLState:  " + b.getSQLState());
                        System.err.println("Message:  " + b.getMessage());
                        System.err.println("Vendor:  " + b.getErrorCode());
                        System.err.print("Update counts:  ");
                        int [] updateCounts = b.getUpdateCounts();
                        for (int i = 0; i < updateCounts.length; i++) {
                                System.err.print(updateCounts[i"   ");
                        }
                        System.err.println("");
                }
        catch (Exception e)
        {
            e.printStackTrace();
        }
    }
};


 Related Tips

 
< Prev   Next >

Page 1 of 0 ( 0 comments )

You can share your information about this topic using the form below!

Please do not post your questions with this form! Thanks.


Name (required)


E-Mail (required)

Your email will not be displayed on the site - only to our administrator
Homepage(optional)



Comment Enable HTML code : Yes No



 
       
         
     
 
 
 
   
 
 
java bottom left
java bottom middle
java bottom right
RSS 0.91 FeedRSS 1.0 FeedRSS 2.0 FeedATOM FeedOPML Feed

Home - About Us - Privacy Policy
Copyright 2005 - 2008 www.java-tips.org
Java is a trademark of Sun Microsystems, Inc.