All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.sfm.jdbc.JdbcMapper Maven / Gradle / Ivy

Go to download

Java library to map flat record - ResultSet, csv - to java object with minimum configuration and low footprint.

There is a newer version: 1.10.3
Show newest version
package org.sfm.jdbc;

import org.sfm.map.Mapper;
import org.sfm.map.MappingException;
import org.sfm.utils.RowHandler;

import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.Iterator;
//IFJAVA8_START
import java.util.stream.Stream;
//IFJAVA8_END


/**
 * JdbcMapper will map from a {@link java.sql.ResultSet} to an object of the specified type T
 * 

* JdbcMapper are instantiable via {@link org.sfm.jdbc.JdbcMapperFactory}. *

* * JdbcMapper<MyClass> mapper = JdbcMapperFactory.newInstance().newMapper(MyClass.class);
*
* ...
*
* try (ResultSet rs : ps.executeQuery()){
*     mapper.stream(rs).forEach(System.out::println);
* }
*
* * @param the type that the mapper is mapping to * @see org.sfm.jdbc.JdbcMapperFactory */ public interface JdbcMapper extends Mapper { /** * Loop over the resultSet, map each row to a new instance of T and call back the handler *

* The method will return the handler passed as an argument so you can easily chain the calls like
* * List<T> list = mapper.forEach(rs, new ListHandler<T>()).getList(); * *
* * @param rs the resultSet * @param handle the handler that will get the callback * @param the row handler type * @return the handler passed in * @throws SQLException if sql error occurs * @throws MappingException if an error occurs during the mapping * */ > H forEach(ResultSet rs, H handle) throws SQLException, MappingException; /** * * @param rs the result set * @return an iterator that will return a map object for each row of the result set. * @throws SQLException if sql error occurs * @throws MappingException if an error occurs during the mapping */ Iterator iterator(ResultSet rs) throws SQLException, MappingException; @Deprecated Iterator iterate(ResultSet rs) throws SQLException, MappingException; /** * * @param rs the result set * @return a stream that will contain a map object for each row of the result set. * @throws SQLException if sql error occurs * @throws MappingException if an error occurs during the mapping */ //IFJAVA8_START Stream stream(ResultSet rs) throws SQLException, MappingException; //IFJAVA8_END }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy