Super Cool Connection Pool

While working on the 4.0 documentation some months ago, I put together some documentation on connection pooling with NetBeans IDE 4.0, Tomcat, and MySQL (click here for details). It was a fun little area to work on and it was cool to see how, thanks to the integration of Tomcat's Admin tool with the IDE's Runtime window, everything can be set up very very quickly. So, this morning, 10 minutes ago, I thought to myself: "Let's see if it's just as easy with NetBeans IDE 4.1, the Sun Java System Application Server, and PointBase." (After all, a disadvantage with using MySQL is that you've got to download everything first, while PointBase is -- currently, anyway -- simply bundled with the IDE. Also, PointBase includes two sample databases, one of which is used below.)

So, that was 10 minutes ago. It really went amazingly quickly -- and I didn't have to type any code in anywhere. Everything, from start to finish, was done by using the mouse to select menu items. I'm going to do it again now, and start completely from scratch, by removing my user directory. After that, these are the only steps needed:

  1. Register the Sun Java System Application Server. (Go to Tools > Server Manager.)
  2. Start PointBase database. (Go to Tools > PointBase database > Start Local PointBase database.)
  3. Go to Runtime window, expand Databases node, right-click jdbc:pointbase://localhost:9092/sample node, click connect.
  4. Expand the Tables node, right-click the CUSTOMER_TBL node, choose View Data. (We'll display the NAME and CITY fields in a JSP page.)
  5. Create a new web application. (Go to File > New Project and use all the defaults.)
  6. Right-click the project node, choose New > File/Folder > Sun Resources > JDBC Resource.
  7. Click Next, click "Create New JDBC Connection Pool", click Next and Next again.
  8. Click "Extract from Existing Connection" > select jdbc:pointbase://localhost:9092/sample > click Next and then Finish.
  9. Start the Sun Java System Application Server 8.1. (Go to Runtime window, expand the Servers node, right-click the server.)
  10. Go back to the Projects window, expand the Server Resources node, right-click the "datasource" and "connectionPool" nodes separately and choose Register for each.
That's it. And now put some code in a JSP page (such as the index.jsp page that's created for you when you create the project) to access the JDBC resource:

  1. At the top of the page:
        <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>
        <%@ taglib prefix="sql" uri="http://java.sun.com/jsp/jstl/sql"%>
    Then, right-click the Libraries node, choose Add Library, select JSTL 1.1, click Add Library.

  2. Above the <html> tag:
       <sql:setDataSource var="datasource"
    	url="jdbc:pointbase://localhost:9092/sample" driver="com.pointbase.jdbc.jdbcDataSource"
    	user="pbpublic" password="pbpublic"/>
       <sql:query var="queryresults" dataSource="${datasource}">
    	SELECT \* FROM CUSTOMER_TBL
       </sql:query>
  3. In the body of the JSP page:
        <table border=1>
          <tr>
    	 <th>Name</th><th>City</th>
          </tr>
          <c:forEach var="row" items="${queryresults.rows}">
    	 <tr>
    	     <td><c:out value="${row.NAME}" /></td>
    	     <td><c:out value="${row.CITY}" /></td>
    	 </tr>
          </c:forEach>
        </table>
  4. Now right-click the project node in the Projects window, choose Run Project, et voila:

Comments:

Post a Comment:
  • HTML Syntax: NOT allowed
About

Geertjan Wielenga (@geertjanw) is a Principal Product Manager in the Oracle Developer Tools group living & working in Amsterdam. He is a Java technology enthusiast, evangelist, trainer, speaker, and writer. He blogs here daily.

The focus of this blog is mostly on NetBeans (a development tool primarily for Java programmers), with an occasional reference to NetBeans, and sometimes diverging to topics relating to NetBeans. And then there are days when NetBeans is mentioned, just for a change.

Search

Archives
« April 2014
SunMonTueWedThuFriSat
  
12
13
14
18
19
20
21
22
23
24
25
26
27
28
29
30
   
       
Today