[#2520] Added API
This commit is contained in:
parent
b4165fbab7
commit
6e84723cab
@ -37,7 +37,19 @@ package org.jooq;
|
||||
/**
|
||||
* A <code>RecordMapper</code> is a mapper that can receive {@link Record}
|
||||
* objects, when fetching data from the database, transforming them into a
|
||||
* custom type <code><E></code>
|
||||
* custom type <code><E></code>.
|
||||
* <p>
|
||||
* <code>RecordMapper</code> is used behind the scenes in methods like
|
||||
* {@link ResultQuery#fetchInto(Class)}, {@link Result#into(Class)},
|
||||
* {@link Record#into(Class)} and other methods called <code>into(Class)</code>,
|
||||
* where the argument class is a <code>Class</code> of type <code>E</code>.
|
||||
* <p>
|
||||
* The default <code>RecordMapper</code> behaviour in the context of a
|
||||
* {@link Configuration} can be overridden through that
|
||||
* <code>configuration</code>'s {@link Configuration#recordMapperProvider()}
|
||||
* SPI.
|
||||
* <p>
|
||||
* The inverse operation is modelled by {@link RecordUnmapper}.
|
||||
*
|
||||
* @author Lukas Eder
|
||||
*/
|
||||
|
||||
70
jOOQ/src/main/java/org/jooq/RecordUnmapper.java
Normal file
70
jOOQ/src/main/java/org/jooq/RecordUnmapper.java
Normal file
@ -0,0 +1,70 @@
|
||||
/*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*
|
||||
* Other licenses:
|
||||
* -----------------------------------------------------------------------------
|
||||
* Commercial licenses for this work are available. These replace the above
|
||||
* ASL 2.0 and offer limited warranties, support, maintenance, and commercial
|
||||
* database integrations.
|
||||
*
|
||||
* For more information, please visit: http://www.jooq.org/licenses
|
||||
*
|
||||
*
|
||||
*
|
||||
*
|
||||
*
|
||||
*
|
||||
*
|
||||
*
|
||||
*
|
||||
*
|
||||
*
|
||||
*
|
||||
*
|
||||
*/
|
||||
package org.jooq;
|
||||
|
||||
import org.jooq.exception.MappingException;
|
||||
|
||||
/**
|
||||
* A <code>RecordUnmapper</code> is a mapper that can receive user objects and
|
||||
* convert them back to {@link Record}.
|
||||
* <p>
|
||||
* <code>RecordUnmapper</code> is used behind the scenes in methods like
|
||||
* {@link DSLContext#newRecord(Table, Object)}, {@link Record#from(Object)} and
|
||||
* other methods called <code>from(Object)</code>, where the argument object is
|
||||
* an object of type <code>E</code>.
|
||||
* <p>
|
||||
* The default <code>RecordUnmapper</code> behaviour in the context of a
|
||||
* {@link Configuration} can be overridden through that
|
||||
* <code>configuration</code>'s {@link Configuration#recordUnmapperProvider()}
|
||||
* SPI.
|
||||
* <p>
|
||||
* The inverse operation is modelled by {@link RecordMapper}.
|
||||
*
|
||||
* @author Lukas Eder
|
||||
*/
|
||||
|
||||
@FunctionalInterface
|
||||
|
||||
public interface RecordUnmapper<E, R extends Record> {
|
||||
|
||||
/**
|
||||
* A callback method indicating that the next record has been fetched.
|
||||
*
|
||||
* @param source The source object to copy data from. This is never null.
|
||||
* @throws MappingException wrapping any reflection exception that might
|
||||
* have occurred while mapping records.
|
||||
*/
|
||||
R map(E source) throws MappingException;
|
||||
}
|
||||
Loading…
Reference in New Issue
Block a user