org.springframework.jdbc.object
Class SqlFunction

java.lang.Object
  extended byorg.springframework.jdbc.object.RdbmsOperation
      extended byorg.springframework.jdbc.object.SqlOperation
          extended byorg.springframework.jdbc.object.SqlQuery
              extended byorg.springframework.jdbc.object.MappingSqlQueryWithParameters
                  extended byorg.springframework.jdbc.object.MappingSqlQuery
                      extended byorg.springframework.jdbc.object.SqlFunction
All Implemented Interfaces:
InitializingBean

public class SqlFunction
extends MappingSqlQuery

SQL "function" wrapper for a query that returns a single row of results. The default behavior is to return an int, but that can be overridden by using the methods with an extra return type parameter.

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 normally 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.

Like all RdbmsOperation objects, SqlFunction objects are threadsafe.

Author:
Rod Johnson, Isabelle Muszynski, Jean-Pierre Pawlak
See Also:
StoredProcedure

Nested Class Summary
 
Nested classes inherited from class org.springframework.jdbc.object.MappingSqlQueryWithParameters
MappingSqlQueryWithParameters.ResultReaderImpl
 
Field Summary
 
Fields inherited from class org.springframework.jdbc.object.RdbmsOperation
logger
 
Constructor Summary
SqlFunction()
          Constructor to allow use as a JavaBean.
SqlFunction(DataSource ds, String sql)
          Create a new SQLFunction object with SQL, but without parameters.
SqlFunction(DataSource ds, String sql, int retType)
          Create a new SQLFunction object with SQL and return type, but without parameters.
SqlFunction(DataSource ds, String sql, int[] types)
          Create a new SQLFunction object with SQL and parameters.
SqlFunction(DataSource ds, String sql, int[] types, int retType)
          Create a new SQLFunction object with SQL, parameters and a return type
 
Method Summary
protected  Object mapRow(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 p)
          Convenient method to run the function with a single int argument.
 int run(Object[] args)
          Analogous to the SqlQuery.execute([]) method.
 Object runGeneric()
          Convenient method to run the function without arguments, returning the value as an object
 Object runGeneric(int p)
          Convenient method to run the function with a single int argument.
 Object runGeneric(Object[] args)
          Analogous to the SqlQuery.execute([]) method.
 
Methods inherited from class org.springframework.jdbc.object.MappingSqlQuery
mapRow
 
Methods inherited from class org.springframework.jdbc.object.MappingSqlQueryWithParameters
newResultReader
 
Methods inherited from class org.springframework.jdbc.object.SqlQuery
execute, execute, execute, execute, execute, execute, execute, execute, execute, execute, execute, execute, findObject, findObject, findObject, findObject, findObject, findObject, findObject, findObject, findObject, findObject, getRowsExpected, setRowsExpected
 
Methods inherited from class org.springframework.jdbc.object.SqlOperation
compileInternal, newPreparedStatementCreator, newPreparedStatementSetter, onCompileInternal
 
Methods inherited from class org.springframework.jdbc.object.RdbmsOperation
afterPropertiesSet, compile, declareParameter, getDeclaredParameters, getGeneratedKeysColumnNames, getJdbcTemplate, getResultSetType, getSql, isCompiled, isReturnGeneratedKeys, isUpdatableResults, setDataSource, setFetchSize, setGeneratedKeysColumnNames, setJdbcTemplate, setMaxRows, setResultSetType, setReturnGeneratedKeys, setSql, setTypes, setUpdatableResults, supportsLobParameters, validateParameters
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Constructor Detail

SqlFunction

public SqlFunction()
Constructor to allow use as a JavaBean. A DataSource, SQL and any parameters must be supplied before invoking the compile method and using this object.

See Also:
RdbmsOperation.setDataSource(javax.sql.DataSource), RdbmsOperation.setSql(java.lang.String), RdbmsOperation.compile()

SqlFunction

public SqlFunction(DataSource ds,
                   String sql)
Create a new SQLFunction object with SQL, but without parameters. Must add parameters or settle with none.

Parameters:
ds - DataSource to obtain connections from
sql - SQL to execute

SqlFunction

public SqlFunction(DataSource ds,
                   String sql,
                   int[] types)
Create a new SQLFunction object with SQL and parameters.

Parameters:
ds - DataSource to obtain connections from
sql - SQL to execute
types - SQL types of the parameters, as defined in the java.sql.Types class
See Also:
Types

SqlFunction

public SqlFunction(DataSource ds,
                   String sql,
                   int retType)
Create a new SQLFunction object with SQL and return type, but without parameters. Must add parameters or settle with none.

Parameters:
ds - DataSource to obtain connections from
sql - SQL to execute
retType - SQL type of the return value, as defined in the java.sql.Types class
See Also:
Types

SqlFunction

public SqlFunction(DataSource ds,
                   String sql,
                   int[] types,
                   int retType)
            throws InvalidDataAccessApiUsageException
Create a new SQLFunction object with SQL, parameters and a return type

Parameters:
ds - DataSource to obtain connections from
sql - SQL to execute
types - SQL types of the parameters, as defined in the java.sql.Types class
retType - SQL type of the return value, as defined in the java.sql.Types class
Throws:
InvalidDataAccessApiUsageException - is thrown if the return type is not numeric or char
See Also:
Types
Method Detail

mapRow

protected Object mapRow(ResultSet rs,
                        int rowNum)
                 throws SQLException,
                        InvalidDataAccessApiUsageException
This implementation of this method extracts a single value from the single row returned by the function. If there are a different number of rows returned, this is treated as an error.

Specified by:
mapRow in class MappingSqlQuery
Parameters:
rs - ResultSet we're working through
rowNum - row number (from 0) we're up to
Returns:
an object of the result type
Throws:
SQLException - if there's an error extracting data. Subclasses can simply not catch SQLExceptions, relying on the framework to clean up.
InvalidDataAccessApiUsageException

run

public int run()
Convenient method to run the function without arguments.

Returns:
the value of the function

run

public int run(int p)
Convenient method to run the function with a single int argument.

Parameters:
p - single int argument
Returns:
the value of the function

run

public int run(Object[] args)
Analogous to the SqlQuery.execute([]) method. This is a generic method to execute a query, taken a number of arguments.

Parameters:
args - array of arguments. These will be objects or object wrapper types for primitives.
Returns:
the value of the function

runGeneric

public Object runGeneric()
Convenient method to run the function without arguments, returning the value as an object

Returns:
the value of the function

runGeneric

public Object runGeneric(int p)
Convenient method to run the function with a single int argument.

Parameters:
p - single int argument
Returns:
the value of the function as an Object

runGeneric

public Object runGeneric(Object[] args)
Analogous to the SqlQuery.execute([]) method. This is a generic method to execute a query, taken a number of arguments.

Parameters:
args - array of arguments. These will be objects or object wrapper types for primitives.
Returns:
the value of the function, as an Object


Copyright (C) 2003-2004 The Spring Framework Project.