1 / 35

Database Processing with JSP

Learn how to retrieve and update customer records from a database using Java Server Pages (JSP) and JDBC. Includes step-by-step instructions and examples.

earle
Download Presentation

Database Processing with JSP

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Database Processing with JSP ISYS 350

  2. Database Applications Queries/Updates Applications Database Server Results

  3. Database: Customer tableFields: CID, Cname, City, RatingExample: Enter CID in a box and retrieve the customer record

  4. Create a CID ListBox

  5. SQL Select Command 1. Select all records from a table: SELECT * FROM tableName; Ex. SELECT * FROM customer; 2. Select records meeting criteria: SELECT * FROM tableName WHERE criteria; Ex. SELECT * FROM customer WHERE city=‘SF’; 3. Select one field from a table: Ex,CID of the Customer table SELECT CID FROM CUSTOMER; 3. Select a few fields from a table: Ex,CID, Cnameof the Customer table Ex. SELECT CID, CnameFROM customer;

  6. Creating a String Containing SQL Select Command • Assuming the CID is entered in a HTML textbox named “cid” or selected from a HTML listbox named “cid”: • String myCIDS, strSQL; • myCid=request.getParameter("cid"); • strSQL="select * from customer where cid='" + myCid + "'";

  7. Creating a Java DB (Derby) Database with NetBeans • Tutorial: • http://netbeans.org/kb/docs/ide/java-db.html#starting

  8. 1. Creating a Database: Click Services tab; open databases node; right click Java DB and select Start Server; then select Create Database Note: You may leave username and password blank or assign a name and password.

  9. Difference between with Username and No username • No username: Create table in the App folder • With username: create table in the default username’s folder

  10. 2. Connect to the database: Right click database name

  11. Connected Database

  12. 3. Creating a New Table: Open the App folder, and:1.Right click Tables and select create table2. Enter Table name3. Click Add column to define field

  13. Create a New Table • Table name: Customer • Fields: • CID: Type – CHAR with size 5; primary key • Cname: Type – CHAR with size 20 • City:Type – CHAR with size 20 • Rating: Type – CHAR with size 1

  14. To insert records to a table: • Right-click the table name and select View Data • From the record view window, click the Insert Record button: Note: Click Add Row to continue adding new row; click OK after entering the last row.

  15. Database Processing with JSP • Java Database Connectivity (JDBC) is an application program interface (API) specification for connecting programs written in Java to the data in popular databases. • Must import java.sql using page directive: • <%@page import="java.sql.*" %> • Need a database driver: • Java Derby database: • jdbc:derby

  16. Define a connection string • A connection string is a string that specifies information about a data source and the means of connecting to it. It is passed in code to an underlying driver or provider in order to initiate the connection. • Example: • DBUrl="jdbc:derby://localhost:1527/CRM";

  17. Define Database Objects to Run SQL Select Command • Define a connection object using the connection string: • No password: • connection = DriverManager.getConnection(DBUrl); • With password: • connection = DriverManager.getConnection(DBUrl,"dchao","dchao"); • Define a SQL Statement object: • Statement SQLStatement = connection.createStatement(); • SQL Statement object’s executeQuery method: • executeQuery: This method executes SQL Select statement and create a resultset object: • Example: • strSQL="select * from customer where cid='" + myCid + "'"; • ResultSetrs = SQLStatement.executeQuery(strSQL);

  18. JDBC ResultSet • The rows that satisfy a particular query are called the result set. The number of rows returned in a result set can be zero or more. A user can access the data in a result set using a cursor one row at a time from top to bottom. A cursor can be thought of as a pointer to the rows of the result set that has the ability to keep track of which row is currently being accessed.

  19. ResultSet Methods • Next() : Returns true if the cursor is now positioned on a row and false if the cursor is positioned after the last row. • previous() • first() • last()

  20. Example 1: Result set contains at most one record or no record(selecting record based on primary key) <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1"> <title>Insert title here</title> </head> <body> <form action="getCustomer.jsp" method="post"> <p>Enter CID: <input name="mycid" type="text" size="20" maxlength="20" ></p> <input type="submit" value="Submit"> </form></body> </html>

  21. Jdbc:derby demo: Accessing database CRMxx with no username and password <% Connection connection = null; String DBUrl="jdbc:derby://localhost:1527/CRMxx"; try { String myCid, strSQL, Cname, City, Rating; connection = DriverManager.getConnection(DBUrl); Statement SQLStatement = connection.createStatement(); myCid=request.getParameter("mycid"); strSQL="select * from customer where cid='" + myCid + "'"; ResultSetrs = SQLStatement.executeQuery(strSQL); if (rs.next()) { Cname=rs.getString("CNAME"); City=rs.getString("CITY"); Rating=rs.getString("Rating"); rs.close(); out.println("Cname: <input type='text' name='name' size='20' value='" + Cname + "' /><br>"); out.println("City: <input type='text' name='city' size='20' value='" + City+ "' /><br>"); out.println("Rating: <input type='text' name='rating' size='3' value='" + Rating + "' /><br>"); } else { out.println("Customer not exist!"); } rs.close(); } catch(SQLException e) { out.println("Something wrong"); out.println(e.getMessage()); } %>

  22. <% Connection connection = null; String DBUrl="jdbc:derby://localhost:1527/CRM5"; try { String myCid, strSQL, Cname, City, Rating; connection = DriverManager.getConnection(DBUrl,"dchao","dchao"); Statement SQLStatement = connection.createStatement(); myCid=request.getParameter("mycid"); strSQL="select * from customer where cid='" + myCid + "'"; ResultSetrs = SQLStatement.executeQuery(strSQL); if (rs.next()) { Cname=rs.getString("CNAME"); City=rs.getString("CITY"); Rating=rs.getString("Rating"); rs.close(); out.println("Cname: <input type='text' name='name' size='20' value='" + Cname + "' /><br>"); out.println("City: <input type='text' name='city' size='20' value='" + City+ "' /><br>"); out.println("Rating: <input type='text' name='rating' size='3' value='" + Rating + "' /><br>"); } else { out.println("Customer not exist!"); } rs.close(); } catch(SQLException e) { out.println("Something wrong"); out.println(e.getMessage()); } %>

  23. Jdbc:derby demoUsingJSPexpression <% Connection connection = null; String DBUrl="jdbc:derby://localhost:1527/CRM5"; try { String myCid, strSQL, Cname, City, Rating; connection = DriverManager.getConnection(DBUrl,"dchao","dchao"); Statement SQLStatement = connection.createStatement(); myCid=request.getParameter("mycid"); strSQL="select * from customer where cid='" + myCid + "'"; ResultSetrs = SQLStatement.executeQuery(strSQL); if (rs.next()) { Cname=rs.getString("CNAME"); City=rs.getString("CITY"); Rating=rs.getString("Rating"); rs.close(); %> Cname: <input type="text" name="name" size="20" value="<%=Cname%>"><br> City: <input type="text" name="city" size="20" value="<%=City%>"><br> Rating: <input type="text" name="rating" size="3" value="<%=Rating%>"><br> <% } else { out.println("Customer not exist!"); rs.close(); } } catch(SQLException e) { out.println("Something wrong"); out.println(e.getMessage()); } %>

  24. Example 2: Result set contains many keys Populate a Listbox using a ResultSet <form name="cidForm" method ="post" action="getCustomer.jsp"> Select CID:<select name="mycid"> <% Connection connection = null; String DBUrl="jdbc:derby://localhost:1527/CRMxx"; try { String myCid, strSQL; connection = DriverManager.getConnection(DBUrl); Statement SQLStatement = connection.createStatement(); strSQL="select cid from customer"; ResultSetrs = SQLStatement.executeQuery(strSQL); while (rs.next()) { myCid=rs.getString("cid"); out.println("<option value='" +myCid + "'>" + myCid + "</option>"); } } catch(SQLException e) { out.println(e.getMessage()); } %> </select> <input type="submit" value="GetCustomerData" name="btnSubmit" /> </form>

  25. Example 3: Result set contains many recordsShow Records in a Table <% Connection connection = null; String DBUrl="jdbc:derby://localhost:1527/CRMxx"; try { String Cid, strSQL, Cname, City, Rating; connection = DriverManager.getConnection(DBUrl); Statement SQLStatement = connection.createStatement(); strSQL="select * from customer"; ResultSetrs = SQLStatement.executeQuery(strSQL); out.println("<table border='1' width='400' cellspacing=1>"); out.println(" <thead><tr>"); out.println("<th>CID</th> <th>Cname</th> <th>City</th> <th>Rating</th>"); out.println("</tr></thead>"); while (rs.next()) { Cid=rs.getString("CID"); Cname=rs.getString("CNAME"); City=rs.getString("CITY"); Rating=rs.getString("Rating"); out.println("<tr>"); out.println("<td>" + Cid + "</td>"); out.println("<td>" + Cname + "</td>"); out.println("<td>" + City + "</td>"); out.println("<td>" + Rating + "</td>"); out.println("</tr>"); } rs.close(); } catch(SQLException e) { out.println(e.getMessage()); } out.println("</table>"); %>

  26. Derby demo:Show Records in a Table using JSP Expression <% Connection connection = null; String DBUrl="jdbc:derby://localhost:1527/CRM5"; try { String Cid, strSQL, Cname, City, Rating; connection = DriverManager.getConnection(DBUrl,"dchao","dchao"); Statement SQLStatement = connection.createStatement(); strSQL="select * from customer"; ResultSetrs = SQLStatement.executeQuery(strSQL); %> <table border='1' width='400' cellspacing=1> <thead> <tr> <th>CID</th> <th>Cname</th> <th>City</th> <th>Rating</th> </tr> </thead> <% while (rs.next()) { Cid=rs.getString("CID"); Cname=rs.getString("CNAME"); City=rs.getString("CITY"); Rating=rs.getString("Rating"); %> <tr> <td width='25%'><%=Cid%></td> <td width='25%'><%=Cname%></td> <td width='25%'><%=City%></td> <td width='25%'><%=Rating%></td> </tr> <% } rs.close(); } catch(SQLException e) { out.println(e.getMessage()); } %> </table>

  27. New Customer Data Entry <form name="newForm" action="addNewCustomer.jsp" method="POST"> Customer Data Entry Form<br><br> Enter CID: <input type="text" name="mycid" value="" /><br><br> Enter Name: <input type="text" name="cname" value="" /><br><br> Enter City: <input type="text" name="city" value="" /><br><br> Enter rating: <input type="text" name="rating" value="" /><br><br> <input type="submit" value="Add New Customer" name="btnSubmit" /> </form>

  28. SQL Insert Command INSERT INTO tableName VALUES (field values separated by commas); Ex 1. Customer table with CID, CNAME, CITY, RATING. INSERT INTO CUSTOMER VALUES (‘C1’, ‘SMITH’, ‘SF’, ‘A’); Ex 2. Orders table with OID, OrderDate, CID, SalesPerson INSERT INTO ORDERS VALUES (‘O11’, ‘9/28/02’, ‘C1’, ‘Peter’);

  29. Creating A String Containing SQL Insert Command myCid=request.getParameter("cid"); myCname=request.getParameter("cname"); myCity=request.getParameter("city"); myRating=request.getParameter("rating"); strSQL= "Insert into Customer values ('"; strSQL+= myCid + "','" + myCname + "','"; strSQL+= myCity + "','" + myRating + "')";

  30. SQL Statement Object’s executeUpdate Method to Run SQL Insert Statement • executeUpdate: This method executes SQL Insert, Delete and Update statement and returns the number of records affected by the statement. • Example: • strSQL = "Insert into Customer values ('"; • strSQL += myCid + "','" + myCname + "','"; • strSQL += myCity + "','" + myRating + "')"; • int Count; • Count=SQLStatement.executeUpdate(strSQL);

  31. Insert a New Record <% Connection connection = null; String DBUrl="jdbc:derby://localhost:1527/CRMxx"; try { String myCid, strSQL, myCname, myCity, myRating; connection = DriverManager.getConnection(DBUrl); Statement SQLStatement = connection.createStatement(); myCid=request.getParameter("mycid"); myCname=request.getParameter("cname"); myCity=request.getParameter("city"); myRating=request.getParameter("rating"); strSQL = "Insert into Customer values ('"; strSQL += myCid + "','" + myCname + "','"; strSQL += myCity + "','" + myRating + "')"; int Count; Count=SQLStatement.executeUpdate(strSQL); if (Count==1) out.println("Insertion sucessful"); } catch(SQLException e) { out.println(e.getMessage()); } %>

  32. Cookie • Cookie is a small data file added by a website to reside in user’s system. • Define a cookie: • new Cookie(“Key”, “value”); • Ex. Cookie cookieCID = new Cookie ("cookieCID",CID); • Write a cookie: • response.addCookie(cookieCID);

  33. Example: <% String CID="C1"; Cookie cookieCID = new Cookie ("cookieCID",CID); response.addCookie(cookieCID); out.println("CID cookie= " + CID + "added"); %>

  34. Reading Cookies Use request.getCookies() method. This method retrieve cookies and return them in an array. <% Cookie[] cookies = request.getCookies(); out.println(cookies[0].getName() + cookies[0].getValue() + "<br>"); %>

  35. Reading Cookie and Customer Record <% try{ String myCid, strSQL, Cname, City, Rating; Cookie[] cookies = request.getCookies(); myCid=cookies[0].getValue(); Connection connection = null; String DBUrl="jdbc:derby://localhost:1527/CRMxx"; connection = DriverManager.getConnection(DBUrl); Statement SQLStatement = connection.createStatement(); strSQL="select * from customer where cid='" + myCid + "'"; ResultSetrs = SQLStatement.executeQuery(strSQL); if (rs.next()) { Cname=rs.getString("CNAME"); City=rs.getString("CITY"); Rating=rs.getString("Rating"); rs.close(); %> Cname: <input type="text" name="name" size="20" value="<%=Cname%>"><br> City: <input type="text" name="city" size="20" value="<%=City%>"><br> Rating: <input type="text" name="rating" size="3" value="<%=Rating%>"><br> <% } else { out.println("Customer not exist!"); rs.close(); } } catch(SQLException e) { out.println(e.getMessage()); } %>

More Related