|
Ok, I've done some reading and stuff on how to handle database records and I think I got it now, but I want someone to verify my thoughts. Instead of accessing my result sets and record processing through the servlets, because they are multithreaded, I'm better off creating a DAO class for each table and using instantiated classes of that because instantiated classes are thread safe yes? My code follows for a simple servlet that saves a new softwareName. Thus I shouldn't get two different threads changing the variables in each one as it goes thru. Thanks, package com.csj.hardwaremaintenance; import java.io.IOException; import java.sql.DatabaseMetaData; import java.util.Hashtable; import javax.naming.InitialContext; import javax.servlet.ServletConfig; import javax.servlet.ServletContext; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpSession; import javax.sql.DataSource; /** * @version 1.0 * @author */ public class SaveSoftwareName extends HttpServlet { private String dsname; private static DataSource ds = null; private DatabaseMetaData dmd; private ServletContext context; private String jdbc_source; private String softnamTable; private static String collectionName; /** * @see javax.servlet.http.HttpServlet#void (javax.servlet.http.HttpServletRequest, javax.servlet.http.HttpServletResponse) */ public void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { performTask(req, resp); } /** * @see javax.servlet.http.HttpServlet#void (javax.servlet.http.HttpServletRequest, javax.servlet.http.HttpServletResponse) */ public void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { performTask(req, resp); } private void getDS() { try { Hashtable parms = new Hashtable(); parms.put( "java.naming.factory.initial", "com.ibm.websphere.naming.WsnInitialContextFactory"); InitialContext cxt = new InitialContext(parms); ds = (DataSource) cxt.lookup("jdbc/" + dsname); } catch (Exception e) { e.printStackTrace(); } } public void init(ServletConfig config) throws ServletException { super.init(config); try { context = getServletContext(); collectionName = context.getInitParameter("misc.lib"); softnamTable = context.getInitParameter("softnam"); dsname = context.getInitParameter("ds.name"); } catch (Exception e) { System.err.println(e); } } public void performTask(HttpServletRequest req, HttpServletResponse resp) { try { if (ds == null) getDS(); HttpSession sess = req.getSession(true); SoftwareNameDAO sd = new SoftwareNameDAO(req, resp, ds, softnamTable, collectionName); String url = ""; String softwareName_error = sd.insertRecord(); if (softwareName_error.equals("")){ url = "addsoftwarenameclose.jsp"; } else { url = "addsoftwarename.jsp"; req.setAttribute("softwareName_error", softwareName_error); } getServletConfig() .getServletContext() .getRequestDispatcher( url).forward( req, resp); } catch (Exception e) { e.printStackTrace(); } } } and my DAO /* * Created on May 3, 2006 * * */ package com.csj.hardwaremaintenance; import java.sql.DatabaseMetaData; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Connection; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.sql.DataSource; /** * @author RPower * * */ public class SoftwareNameDAO { String softwareName = null; String softwareNotes = null; Connection conn = null; DataSource ds = null; DatabaseMetaData dmd = null; PreparedStatement insertRecord = null; PreparedStatement checkRecord = null; ResultSet rs = null; String collectionName = null; String softnamTable = null; /** * @param req * @param resp * @param ds * @param softwareName * @param softwareNotes */ public SoftwareNameDAO(HttpServletRequest req, HttpServletResponse resp, DataSource ds, String softnamTable, String collectionName) { super(); if (req.getParameter("softwareName") != null) { this.softwareName = (String) req.getParameter("softwareName").toUpperCase(); } else { this.softwareName = ""; } if (req.getParameter("softwareNotes") != null) { this.softwareNotes = (String) req.getParameter("softwareNotes").toUpperCase(); } else { this.softwareNotes = ""; } this.ds = ds; this.softnamTable = softnamTable; this.collectionName = collectionName; } /** * */ public String insertRecord() { String retfield = ""; try { conn = ds.getConnection(); dmd = conn.getMetaData(); checkRecord = conn.prepareStatement( "SELECT * FROM " + collectionName + dmd.getCatalogSeparator() + softnamTable + " WHERE SOFTNM = '" + softwareName.trim() + "'"); rs = checkRecord.executeQuery(); if (rs.next()){ //return error that record exists retfield = "Cannot add record, Software Name '" + softwareName.trim() + "' already exists!"; } else { insertRecord = conn.prepareStatement( "INSERT INTO " + collectionName + dmd.getCatalogSeparator() + softnamTable + " (SOFTNM, SOFTNT) " + "VALUES(?,?)"); insertRecord.setString(1, softwareName); insertRecord.setString(2, softwareNotes); insertRecord.execute(); retfield = ""; } } catch (SQLException e) { e.printStackTrace(); } finally { if(rs!=null){ try { rs.close(); } catch (SQLException e1) { e1.printStackTrace(); } rs = null; } if(checkRecord!=null){ try { checkRecord.close(); } catch (SQLException e1) { e1.printStackTrace(); } checkRecord = null; } if(insertRecord!=null){ try { insertRecord.close(); } catch (SQLException e1) { e1.printStackTrace(); } insertRecord = null; } if(conn!=null){ try { conn.close(); } catch (SQLException e1) { e1.printStackTrace(); } conn = null; } } return retfield; } } Ron Power Programmer Information Services City Of St. John's, NL P.O. Box 908 St. John's, NL A1C 5M2 709-576-8132 rpower@xxxxxxxxxx http://www.stjohns.ca/ ___________________________________________________________________________ Success is going from failure to failure without a loss of enthusiasm. - Sir Winston Churchill This email communication and accompanying documents is intended only for the individual or entity to which it is addressed and may contain information that is confidential, privileged or exempt from disclosure under applicable law. Any use of this information by individuals or entities other than the intended recipient is strictly prohibited. If you have received this in error, please notify the sender and delete all the copies (electronic or otherwise) immediately.
As an Amazon Associate we earn from qualifying purchases.
This mailing list archive is Copyright 1997-2025 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].
Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.