Class NullDelegatingMapper<T>
- java.lang.Object
-
- org.jdbi.v3.core.mapper.reflect.internal.NullDelegatingMapper<T>
-
- Type Parameters:
T-
- All Implemented Interfaces:
RowMapper<T>
public final class NullDelegatingMapper<T> extends java.lang.Object implements RowMapper<T>
Delegating mapper that implements the @PropagateNull semantics to check a specific column in the result set for null first. If that column is null, return null as the value, otherwise executed the delegated mapper.
-
-
Constructor Summary
Constructors Constructor Description NullDelegatingMapper(int index, RowMapper<T> delegate)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidinit(ConfigRegistry registry)Allows for initialization of the row mapper instance within a ConfigRegistry scope.Tmap(java.sql.ResultSet rs, StatementContext ctx)Map the current row of the result set.RowMapper<T>specialize(java.sql.ResultSet rs, StatementContext ctx)Returns a specialized row mapper, optimized for the given result set.java.lang.StringtoString()
-
-
-
Method Detail
-
init
public void init(ConfigRegistry registry)
Description copied from interface:RowMapperAllows for initialization of the row mapper instance within a ConfigRegistry scope. This method is called once when the row mapper is first used from a ConfigRegistry.Note that handles, statements, sql objects etc. all create copies of the registry, and this method will be called for every copy
- Specified by:
initin interfaceRowMapper<T>- Parameters:
registry- A reference to theConfigRegistrythat this instance belongs to.
-
map
public T map(java.sql.ResultSet rs, StatementContext ctx) throws java.sql.SQLException
Description copied from interface:RowMapperMap the current row of the result set. This method should not cause the result set to advance; allow Jdbi to do that, please.
-
specialize
public RowMapper<T> specialize(java.sql.ResultSet rs, StatementContext ctx) throws java.sql.SQLException
Description copied from interface:RowMapperReturns a specialized row mapper, optimized for the given result set.Before mapping the result set from a SQL statement; Jdbi will first call this method to obtain a specialized instance. The returned mapper will then be used to map the result set rows, and discarded.
Implementing this method is optional; the default implementation returns
this. Implementors might choose to override this method to improve performance, e.g. by matching up column names to properties once for the entire result set, rather than repeating the process for every row.- Specified by:
specializein interfaceRowMapper<T>- Parameters:
rs- the result set to specialize overctx- the statement context to specialize over- Returns:
- a row mapper equivalent to this one, possibly specialized.
- Throws:
java.sql.SQLException- if anything goes wrong go ahead and let this percolate; Jdbi will handle it- See Also:
for an example of specialization.
-
toString
public java.lang.String toString()
- Overrides:
toStringin classjava.lang.Object
-
-