package com.jspservletcookbook;
import java.sql.*;
import java.util.ArrayList;
import java.util.List;
import java.util.Iterator;
import javax.naming.Context;
import javax.naming.InitialContext;
import javax.naming.NamingException;
import javax.sql.*;
import javax.servlet.*;
import javax.servlet.http.*;
public class DbMetaServlet extends HttpServlet {
DataSource pool;
public void init() throws ServletException {
Context env = null;
try{
env = (Context) new InitialContext().lookup("java:comp/env");
pool = (DataSource) env.lookup("jdbc/oracle-8i-athletes");
if (pool == null)
throw new ServletException("'oracle-8i-athletes' is an unknown DataSource");
} catch (NamingException ne) {
throw new ServletException(ne);
}
}
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, java.io.IOException {
String sql = "select * from athlete";
Connection conn = null;
Statement stmt = null;
ResultSet rs = null;
ResultSetMetaData rsm = null;
response.setContentType("text/html");
java.io.PrintWriter out = response.getWriter();
out.println("<html><head><title>Discover a ResultSet</title></head><body>");
out.println("<h2>Here is Info about the returned ResultSet</h2>");
out.println("<table border='1'><tr>");
try{
//Get a connection from the pool
conn = pool.getConnection();
//Create a Statement with which to run some SQL
stmt = conn.createStatement();
//Execute the SQL
rs = stmt.executeQuery(sql);
//Get a ResultSetMetaData object from the ResultSet
rsm = rs.getMetaData();
int colCount = rsm.getColumnCount();
//print column names
printMeta(rsm,"name",out,colCount);
//print column index
printMeta(rsm,"index",out,colCount);
//print column type
printMeta(rsm,"column type",out,colCount);
//print column display size
printMeta(rsm,"column display",out,colCount);
} catch (Exception e){
throw new ServletException(e.getMessage());
} finally {
try{
stmt.close();
conn.close();
} catch (SQLException sqle){ }
}
out.println("</table></body></html>");
out.close();
} //doGet
private void printMeta(ResultSetMetaData metaData, String type,
java.io.PrintWriter out, int colCount) throws SQLException {
if (metaData == null || type == null || out == null)
throw new IllegalArgumentException("Illegal args passed to printMeta()");
out.println("<tr>");
if (type.equals("table")){
out.println("<td><strong>Table name</strong></td>");
for (int i = 1; i <=colCount; ++i){
out.println("<td>" + metaData.getTableName(i) + "</td>");
}
} else if (type.equals("name")){
out.println("<td><strong>Column name</strong></td>");
for (int i = 1; i <=colCount; ++i){
out.println("<td>" + metaData.getColumnName(i) + "</td>");
}
} else if (type.equals("index")){
out.println("<td><strong>Column index</strong></td>");
for (int i = 1; i <=colCount; ++i){
out.println("<td>" + i + "</td>");
}
} else if (type.equals("column type")){
out.println("<td><strong>Column type</strong></td>");
for (int i = 1; i <=colCount; ++i){
out.println("<td>" + metaData.getColumnTypeName(i) + "</td>");
}
} else if (type.equals("column display")){
out.println("<td><strong>Column display size</strong></td>");
for (int i = 1; i <=colCount; ++i){
out.println("<td>" + metaData.getColumnDisplaySize(i) + "</td>");
}
}
out.println("</tr>");
}//printMeta
}
|