com.darwinsys.sql.ResultsDecoratorHTML Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of darwinsys-api Show documentation
Show all versions of darwinsys-api Show documentation
Ian Darwin's assorted Java stuff,
assembled as an API.
/* Copyright (c) Ian F. Darwin, http://www.darwinsys.com/, 2004-2006.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS''
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
* TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS
* BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*/
package com.darwinsys.sql;
// BEGIN main
import java.io.*;
import java.sql.*;
import com.darwinsys.util.Verbosity;
/** Print ResultSet in HTML
*/
public class ResultsDecoratorHTML extends ResultsDecorator {
public ResultsDecoratorHTML(PrintWriter out, Verbosity v) {
super(out, v);
}
public int write(ResultSet rs) throws IOException, SQLException {
ResultSetMetaData md = rs.getMetaData();
int colCount = md.getColumnCount();
println("");
print("");
for (int i=1; i<=colCount; i++) {
print("");
print(md.getColumnLabel(i));
}
println(" ");
int rowCount = 0;
while (rs.next()) {
++rowCount;
print("");
for (int i=1; i<=colCount; i++) {
print("");
print(rs.getString(i));
}
println(" ");
}
println("
");
return rowCount;
}
@Override
public void displayTable(String table, ResultSet rs) throws IOException, SQLException {
write(rs);
}
/** Return a printable name for this decorator
* @see ResultsDecorator#getName()
*/
public String getName() {
return "HTML";
}
}
// END main