is.codion.common.db.result.ResultPacker Maven / Gradle / Ivy
/*
* This file is part of Codion.
*
* Codion is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Codion is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with Codion. If not, see .
*
* Copyright (c) 2008 - 2024, Björn Darri Sigurðsson.
*/
package is.codion.common.db.result;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
import static java.util.Objects.requireNonNull;
/**
* A ResultPacker packs the contents of a ResultSet into a List.
* @param the type of object resulting from the packing
*/
public interface ResultPacker {
/**
* Iterates through the given ResultSet, packing its contents into a List using {@link #get(ResultSet)} in the order they appear.
* Items are skipped if {@link #get(ResultSet)} returns null.
* This method does not close the ResultSet.
* @param resultSet the ResultSet instance containing the query result to process
* @return a List containing the data from the query result
* @throws SQLException thrown if anything goes wrong during the packing
* @throws NullPointerException in case resultSet is null
*/
default List pack(ResultSet resultSet) throws SQLException {
requireNonNull(resultSet);
List result = new ArrayList<>();
while (resultSet.next()) {
T item = get(resultSet);
if (item != null) {
result.add(item);
}
}
return result;
}
/**
* Fetches a single instance from the given result set, assuming {@link ResultSet#next()} has been called
* @param resultSet the result set
* @return the instance fetched from the ResultSet
* @throws SQLException in case of failure
*/
T get(ResultSet resultSet) throws SQLException;
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy