fr.opensagres.xdocreport.document.sql.SQLDataProvider Maven / Gradle / Ivy
/**
* Copyright (C) 2011-2015 The XDocReport Team
*
* All rights reserved.
*
* Permission is hereby granted, free of charge, to any person obtaining
* a copy of this software and associated documentation files (the
* "Software"), to deal in the Software without restriction, including
* without limitation the rights to use, copy, modify, merge, publish,
* distribute, sublicense, and/or sell copies of the Software, and to
* permit persons to whom the Software is furnished to do so, subject to
* the following conditions:
*
* The above copyright notice and this permission notice shall be
* included in all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
* LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
* OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
*/
package fr.opensagres.xdocreport.document.sql;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.Collection;
import java.util.HashMap;
import java.util.Map;
import fr.opensagres.xdocreport.core.utils.StringUtils;
import fr.opensagres.xdocreport.template.IContext;
import fr.opensagres.xdocreport.template.formatter.FieldsMetadata;
/**
* XDocReport support for SQL {@link ResultSet}. The implementation of this class
*
* - transform a {@link ResultSet} to {@link Map} which can be used instead of {@link IContext}.
* - update the {@link FieldsMetadata} with simple and list field from the {@link ResultSet}.
*
*/
public abstract class SQLDataProvider
extends HashMap
{
private static final long serialVersionUID = 6237301616073252200L;
/**
* SQL Data provider constructor.
*
* @param rs the SQL {@link ResultSet}
* @param metadata the {@link FieldsMetadata}.
* @throws SQLException
*/
public SQLDataProvider( ResultSet rs, FieldsMetadata metadata )
throws SQLException
{
Map pojoItem = null;
// Loop for each row of the ResultSet.
while ( rs.next() )
{
pojoItem = null;
int columnCount = getColumnCount( rs );
String tableName = null;
String columnLabel = null;
// Loop for column of the current row
for ( int columnIndex = 1; columnIndex < columnCount + 1; columnIndex++ )
{
// retrieve table name + column label.
tableName = getTableName( rs, columnIndex );
columnLabel = getColumnLabel( rs, columnIndex );
String listName = getListName( tableName, columnLabel );
if ( listName != null )
{
// The field is a list, build a Collection
Collection
© 2015 - 2025 Weber Informatics LLC | Privacy Policy