T
- the result typepublic class SqlFunction<T> extends MappingSqlQuery<T>
Intended to use to call SQL functions that return a single result using a query like "select user()" or "select sysdate from dual". It is not intended for calling more complex stored functions or for using a CallableStatement to invoke a stored procedure or stored function. Use StoredProcedure or SqlCall for this type of processing.
This is a concrete class, which there is often no need to subclass.
Code using this package can create an object of this type, declaring SQL
and parameters, and then invoke the appropriate run
method
repeatedly to execute the function. Subclasses are only supposed to add
specialized run
methods for specific parameter and return types.
Like all RdbmsOperation objects, SqlFunction objects are thread-safe.
StoredProcedure
MappingSqlQueryWithParameters.RowMapperImpl
logger
Constructor and Description |
---|
SqlFunction()
Constructor to allow use as a JavaBean.
|
SqlFunction(javax.sql.DataSource ds,
java.lang.String sql)
Create a new SqlFunction object with SQL, but without parameters.
|
SqlFunction(javax.sql.DataSource ds,
java.lang.String sql,
int[] types)
Create a new SqlFunction object with SQL and parameters.
|
SqlFunction(javax.sql.DataSource ds,
java.lang.String sql,
int[] types,
java.lang.Class<T> resultType)
Create a new SqlFunction object with SQL, parameters and a result type.
|
Modifier and Type | Method and Description |
---|---|
protected T |
mapRow(java.sql.ResultSet rs,
int rowNum)
This implementation of this method extracts a single value from the
single row returned by the function.
|
int |
run()
Convenient method to run the function without arguments.
|
int |
run(int parameter)
Convenient method to run the function with a single int argument.
|
int |
run(java.lang.Object... parameters)
Analogous to the SqlQuery.execute([]) method.
|
java.lang.Object |
runGeneric()
Convenient method to run the function without arguments,
returning the value as an object.
|
java.lang.Object |
runGeneric(int parameter)
Convenient method to run the function with a single int argument.
|
java.lang.Object |
runGeneric(java.lang.Object[] parameters)
Analogous to the
SqlQuery.findObject(Object[]) method. |
void |
setResultType(java.lang.Class<T> resultType)
Specify the type that the result object is required to match.
|
mapRow
newRowMapper
execute, execute, execute, execute, execute, execute, execute, execute, execute, execute, execute, execute, executeByNamedParam, executeByNamedParam, findObject, findObject, findObject, findObject, findObject, findObject, findObject, findObject, findObject, findObject, findObjectByNamedParam, findObjectByNamedParam, getRowsExpected, setRowsExpected
compileInternal, getParsedSql, newPreparedStatementCreator, newPreparedStatementCreator, newPreparedStatementSetter, onCompileInternal
afterPropertiesSet, allowsUnusedParameters, checkCompiled, compile, declareParameter, getDeclaredParameters, getGeneratedKeysColumnNames, getJdbcTemplate, getResultSetType, getSql, isCompiled, isReturnGeneratedKeys, isUpdatableResults, resolveSql, setDataSource, setFetchSize, setGeneratedKeysColumnNames, setJdbcTemplate, setMaxRows, setParameters, setQueryTimeout, setResultSetType, setReturnGeneratedKeys, setSql, setTypes, setUpdatableResults, supportsLobParameters, validateNamedParameters, validateParameters
public SqlFunction()
compile
method and using this object.public SqlFunction(javax.sql.DataSource ds, java.lang.String sql)
ds
- the DataSource to obtain connections fromsql
- the SQL to executepublic SqlFunction(javax.sql.DataSource ds, java.lang.String sql, int[] types)
ds
- the DataSource to obtain connections fromsql
- the SQL to executetypes
- the SQL types of the parameters, as defined in the
java.sql.Types
classTypes
public SqlFunction(javax.sql.DataSource ds, java.lang.String sql, int[] types, java.lang.Class<T> resultType)
ds
- the DataSource to obtain connections fromsql
- the SQL to executetypes
- the SQL types of the parameters, as defined in the
java.sql.Types
classresultType
- the type that the result object is required to matchsetResultType(Class)
,
Types
public void setResultType(java.lang.Class<T> resultType)
If not specified, the result value will be exposed as returned by the JDBC driver.
@Nullable protected T mapRow(java.sql.ResultSet rs, int rowNum) throws java.sql.SQLException
mapRow
in class MappingSqlQuery<T>
rs
- the ResultSet we're working throughrowNum
- row number (from 0) we're up tojava.sql.SQLException
- if there's an error extracting data.
Subclasses can simply not catch SQLExceptions, relying on the
framework to clean up.public int run()
public int run(int parameter)
parameter
- single int parameterpublic int run(java.lang.Object... parameters)
parameters
- array of parameters. These will be objects or
object wrapper types for primitives.@Nullable public java.lang.Object runGeneric()
@Nullable public java.lang.Object runGeneric(int parameter)
parameter
- single int parameter@Nullable public java.lang.Object runGeneric(java.lang.Object[] parameters)
SqlQuery.findObject(Object[])
method.
This is a generic method to execute a query, taken a number of arguments.parameters
- array of parameters. These will be objects or
object wrapper types for primitives.SqlQuery.execute(Object[])