Example: Developing servlet with user transaction

Example: Developing servlet with user transaction
//===================START_PROLOG======================================
//
//   5630-A23, 5630-A22,
//   (C) COPYRIGHT International Business Machines Corp. 2002
//   All Rights Reserved //   Licensed Materials - Property of IBM
//
//   IBM DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING
//   ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
//   PURPOSE. IN NO EVENT SHALL IBM BE LIABLE FOR ANY SPECIAL, INDIRECT OR
//   CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF
//   USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
//   OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE
//   OR PERFORMANCE OF THIS SOFTWARE.
//
//===================END_PROLOG========================================

package WebSphereSamples.ConnPool;

import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
import java.util.*;
// Import JDBC packages and naming service packages.  Note the lack // of an IBM Extensions package import.  This is no longer required.
import java.sql.*;
import javax.sql.*;
import javax.naming.*;
import javax.transaction.*;

public class EmployeeListTran extends HttpServlet {
    private static DataSource ds   = null;   
    private UserTransaction ut = null;
    private static String title    = "Employee List";    

// ****************************************************************
// * Initialize servlet when it is first loaded.                  *
// * Get information from the properties file, and look up the    *
// * DataSource object from JNDI to improve performance of the    *
// * the servlet's service methods.                               *
// ****************************************************************
    public void init(ServletConfig config)
    throws ServletException     {
        super.init(config);
        getDS();
    }

// ****************************************************************
// * Perform the JNDI lookup for the DataSource and               *
// * User Transaction objects.                                    *           
// * This method is invoked from init(), and from the service     *
// * method of the DataSource is null                             *
// ****************************************************************
    private void getDS() {
        try {
            Hashtable parms = new Hashtable();
            parms.put(Context.INITIAL_CONTEXT_FACTORY, 
 "com.ibm.websphere.naming.WsnInitialContextFactory");
            InitialContext ctx = new InitialContext(parms);
            // Perform a naming service lookup to get the DataSource object.
            ds = (DataSource)ctx.lookup("java:comp/env/jdbc/SampleDB");
            ut = (UserTransaction) ctx.lookup("java:comp/UserTransaction");
        } catch (Exception e) {
            System.out.println("Naming service exception: " + e.getMessage());
            e.printStackTrace();
        }
    }

// ****************************************************************
// * Respond to user GET request                                  *
// ****************************************************************
    public void doGet(HttpServletRequest req, HttpServletResponse res) throws        ServletException, IOException     {
        Connection conn  = null;
        Statement stmt = null;
        ResultSet rs = null;
        Vector employeeList = new Vector();                                                         
// Set retryCount to the number of times you would like to retry after a // StaleConnectionException         int retryCount = 5;      
        // If the Database code processes successfully, we will set error = false         boolean error = true;
        do {
            try {          
                //Start a new Transaction                 ut.begin();
                // Get a Connection object conn using the DataSource factory.                               
 conn = ds.getConnection();
                // Run DB query using standard JDBC coding.
                stmt = conn.createStatement();
                String query   = "Select FirstNme, MidInit, LastName " + 
                                     "from Employee ORDER BY LastName";
                rs   = stmt.executeQuery(query);
                while (rs.next()) {
                    employeeList.addElement(rs.getString(3) + ", " + rs.getString(1) +                                             " " + rs.getString(2));
                }                           
           //Set error to false to indicate successful completion of the database work                 error=false;                    
            } catch (com.ibm.ejs.cm.pool.ConnectionWaitTimeoutException cw) {

              // This exception is thrown if a connection can not be obtained from the               // pool within a configurable amount of time.  Frequent occurrences of               // this exception indicate an incorrectly tuned connection pool 
                System.out.println("Connection Wait Timeout Exception during get connection or process SQL: " + c.getMessage());  
             
//In general, we do not want to retry after this exception, so set retry count to 0
//and rollback the transaction                 try {
                    ut.setRollbackOnly();
                } 
                catch (SecurityException se) {

//Thrown to indicate that the thread is not allowed to roll back the transaction.
                  System.out.println("Security Exception setting rollback only! " +                                          se.getMessage());                
                } 
  catch (IllegalStateException ise) {
//Thrown if the current thread is not associated with a transaction.
                  System.out.println("Illegal State Exception setting rollback only! "                                       + ise.getMessage());                    
                } 
                catch (SystemException sye) {
          //Thrown if the transaction manager encounters an unexpected error condition                     System.out.println("System Exception setting rollback only! " +                                         sye.getMessage());
                }
                retryCount=0;   
            } 
            catch (com.ibm.websphere.ce.cm.StaleConnectionException sc) {

   // This exception indicates that the connection to the database is no longer valid.
   //Rollback the transaction, then retry several times to attempt to obtain a valid      //connection, display an error message if the connection still can not be obtained.

               System.out.println("Stale Connection Exception during get connection or process SQL: " + sc.getMessage());                
               try {
                  ut.setRollbackOnly();
               } 
               catch (SecurityException se) {

     //Thrown to indicate that the thread is not allowed to roll back the transaction.
                  System.out.println("Security Exception setting rollback only! " +                                         se.getMessage());                
               } 
               catch (IllegalStateException ise) {

 //Thrown if the current thread is not associated with a transaction.
                  System.out.println("Illegal State Exception setting rollback only! "                                       + ise.getMessage());                    
                } 
                catch (SystemException sye) {
    //Thrown if the transaction manager encounters an unexpected error condition                    System.out.println("System Exception setting rollback only! " +                                            sye.getMessage());
                }
                if (--retryCount == 0) {
                   System.out.println("Five stale connection exceptions, displaying error page.");            
                }
            } 
            catch (SQLException sq) {
             System.out.println("SQL Exception during get connection or process SQL: "                                  + sq.getMessage());                       

//In general, we do not want to retry after this exception, so set retry count to 0
//and rollback the transaction                try {
                  ut.setRollbackOnly();
               } 
               catch (SecurityException se) {

     //Thrown to indicate that the thread is not allowed to roll back the transaction.
                 System.out.println("Security Exception setting rollback only! " +                                         se.getMessage());                
                } 
                catch (IllegalStateException ise) {
     //Thrown if the current thread is not associated with a transaction.
     System.out.println("Illegal State Exception setting rollback only! "                                       + ise.getMessage());                    
                } 
                catch (SystemException sye) {
     //Thrown if the transaction manager encounters an unexpected error condition                    System.out.println("System Exception setting rollback only! " +                                            sye.getMessage());
                }
                retryCount=0;
            } 
            catch (NotSupportedException nse) {

  //Thrown by UserTransaction begin method if the thread is already associated with a    //transaction and the Transaction Manager implementation does not support nested       //transactions.
               System.out.println("NotSupportedException on User Transaction begin: "                                     + nse.getMessage());
            } 
            catch (SystemException se) {

   //Thrown if the transaction manager encounters an unexpected error condition                System.out.println("SystemException in User Transaction: " +                                 se.getMessage());
            } 
            catch (Exception e) {
               System.out.println("Exception in get connection or process SQL: " +
                                   e.getMessage());                
//In general, we do not want to retry after this exception, so set retry count to 5
//and rollback the transaction                try {
                  ut.setRollbackOnly();
               } 
               catch (SecurityException se) {
  //Thrown to indicate that the thread is not allowed to roll back the transaction.
                  System.out.println("Security Exception setting rollback only! " +                                          se.getMessage());
} 
               catch (IllegalStateException ise) {
  //Thrown if the current thread is not associated with a transaction.
                  System.out.println("Illegal State Exception setting rollback only! "                                       + ise.getMessage());                    
                } 
                catch (SystemException sye) {
  //Thrown if the transaction manager encounters an unexpected error condition                    System.out.println("System Exception setting rollback only! " +                                            sye.getMessage());
                }
                retryCount=0;
            } 
             finally {

                // Always close the connection in a finally statement to ensure proper                 // closure in all cases. Closing the connection does not close and 
                // actual connection, but releases it back to the pool for reuse.

                if (rs != null) {
                   try {
                      rs.close();
                   } 
                   catch (Exception e) {
                      System.out.println("Close Resultset Exception: " +                                                         e.getMessage());
                   }
                }
                if (stmt != null) {
                   try {
   stmt.close();
                   } 
                   catch (Exception e) {
                      System.out.println("Close Statement Exception: " +                                                         e.getMessage());
                   }
                }
                if (conn != null) {
                   try {
                      conn.close();
                   } 
                   catch (Exception e) {
                      System.out.println("Close connection exception: " +                                                        e.getMessage());
                    }
                }
                try {
                    ut.commit();
                } 
                catch (RollbackException re) {

 //Thrown to indicate that the transaction has been rolled back rather than committed.
                   System.out.println("User Transaction Rolled back! " +                                                      re.getMessage());                    
                } 
                catch (SecurityException se) {
 //Thrown to indicate that the thread is not allowed to commit the transaction.
                System.out.println("Security Exception thrown on transaction commit: "                                     + se.getMessage());
                } 
                catch (IllegalStateException ise) {
 //Thrown if the current thread is not associated with a transaction.
 System.out.println("Illegal State Exception thrown on transaction commit: " + ise.getMessage());
                } 
                catch (SystemException sye) {
 //Thrown if the transaction manager encounters an unexpected error condition                   System.out.println("System Exception thrown on transaction commit: "                                       + sye.getMessage());
                } 
                catch (Exception e) {
                   System.out.println("Exception thrown on transaction commit: " +                                            e.getMessage());
                }
            }
        } while ( error==true && retryCount > 0 );        

        // Prepare and return HTML response, prevent dynamic content from being cached         // on browsers.
        res.setContentType("text/html");
        res.setHeader("Pragma", "no-cache");
        res.setHeader("Cache-Control", "no-cache");
        res.setDateHeader("Expires", 0);
        try {
            ServletOutputStream out = res.getOutputStream();
            out.println("<HTML>");
            out.println("<HEAD><TITLE>" + title + "</TITLE></HEAD>");
            out.println("<BODY>");                  
            if (error==true) {
                out.println("<H1>There was an error processing this request.</H1>  Please try the request again, or contact " +
" the <a href='mailto:sysadmin@my.com'>System Administrator</a>");
            } 
            else if (employeeList.isEmpty()) {
               out.println("<H1>Employee List is Empty</H1>");
            } 
            else {
               out.println("<H1>Employee List </H1>");
               for (int i = 0; i < employeeList.size(); i++) {
                  out.println(employeeList.elementAt(i) + "<BR>"); 
               }
            }
            out.println("</BODY></HTML>");
            out.close();
        } 
        catch (IOException e) {
           System.out.println("HTML response exception: " + e.getMessage());
        }
    }
}



Related reference
Administrative console buttons