Package org.springframework.jdbc.object
Class StoredProcedure
java.lang.Object
org.springframework.jdbc.object.RdbmsOperation
org.springframework.jdbc.object.SqlCall
org.springframework.jdbc.object.StoredProcedure
- All Implemented Interfaces:
- InitializingBean
- Direct Known Subclasses:
- GenericStoredProcedure
Superclass for object abstractions of RDBMS stored procedures.
 This class is abstract and it is intended that subclasses will provide a typed
 method for invocation that delegates to the supplied 
execute(java.lang.Object...) method.
 The inherited sql property is the name of the stored procedure
 in the RDBMS.
- Author:
- Rod Johnson, Thomas Risberg
- 
Field SummaryFields inherited from class org.springframework.jdbc.object.RdbmsOperationlogger
- 
Constructor SummaryConstructorsModifierConstructorDescriptionprotectedAllow use as a bean.protectedStoredProcedure(DataSource ds, String name) Create a new object wrapper for a stored procedure.protectedStoredProcedure(JdbcTemplate jdbcTemplate, String name) Create a new object wrapper for a stored procedure.
- 
Method SummaryModifier and TypeMethodDescriptionprotected booleanStoredProcedure parameter Maps are by default allowed to contain additional entries that are not actually used as parameters.voiddeclareParameter(SqlParameter param) Declare a parameter.Execute the stored procedure with the provided parameter values.Execute the stored procedure.execute(ParameterMapper inParamMapper) Execute the stored procedure.Methods inherited from class org.springframework.jdbc.object.SqlCallcompileInternal, getCallString, isFunction, isSqlReadyForUse, newCallableStatementCreator, newCallableStatementCreator, onCompileInternal, setFunction, setSqlReadyForUseMethods inherited from class org.springframework.jdbc.object.RdbmsOperationafterPropertiesSet, checkCompiled, compile, getDeclaredParameters, getGeneratedKeysColumnNames, getJdbcTemplate, getResultSetType, getSql, isCompiled, isReturnGeneratedKeys, isUpdatableResults, resolveSql, setDataSource, setFetchSize, setGeneratedKeysColumnNames, setJdbcTemplate, setMaxRows, setParameters, setQueryTimeout, setResultSetType, setReturnGeneratedKeys, setSql, setTypes, setUpdatableResults, supportsLobParameters, validateNamedParameters, validateParameters
- 
Constructor Details- 
StoredProcedureprotected StoredProcedure()Allow use as a bean.
- 
StoredProcedureCreate a new object wrapper for a stored procedure.- Parameters:
- ds- the DataSource to use throughout the lifetime of this object to obtain connections
- name- the name of the stored procedure in the database
 
- 
StoredProcedureCreate a new object wrapper for a stored procedure.- Parameters:
- jdbcTemplate- the JdbcTemplate which wraps DataSource
- name- the name of the stored procedure in the database
 
 
- 
- 
Method Details- 
allowsUnusedParametersprotected boolean allowsUnusedParameters()StoredProcedure parameter Maps are by default allowed to contain additional entries that are not actually used as parameters.- Overrides:
- allowsUnusedParametersin class- RdbmsOperation
- See Also:
 
- 
declareParameterDeclare a parameter.Parameters declared as SqlParameterandSqlInOutParameterwill always be used to provide input values. In addition to this, any parameter declared asSqlOutParameterwhere a non-null input value is provided will also be used as an input parameter. Note: Calls to declareParameter must be made in the same order as they appear in the database's stored procedure parameter list.Names are purely used to help mapping. - Overrides:
- declareParameterin class- RdbmsOperation
- Parameters:
- param- the parameter object
- Throws:
- InvalidDataAccessApiUsageException- if the parameter has no name, or if the operation is already compiled, and hence cannot be configured further
 
- 
executeExecute the stored procedure with the provided parameter values. This is a convenience method where the order of the passed in parameter values must match the order that the parameters where declared in.- Parameters:
- inParams- variable number of input parameters. Output parameters should not be included in this map. It is legal for values to be- null, and this will produce the correct behavior using a NULL argument to the stored procedure.
- Returns:
- map of output params, keyed by name as in parameter declarations. Output parameters will appear here, with their values after the stored procedure has been called.
 
- 
executeExecute the stored procedure. Subclasses should define a strongly typed execute method (with a meaningful name) that invokes this method, populating the input map and extracting typed values from the output map. Subclass execute methods will often take domain objects as arguments and return values. Alternatively, they can return void.- Parameters:
- inParams- map of input parameters, keyed by name as in parameter declarations. Output parameters need not (but can) be included in this map. It is legal for map entries to be- null, and this will produce the correct behavior using a NULL argument to the stored procedure.
- Returns:
- map of output params, keyed by name as in parameter declarations. Output parameters will appear here, with their values after the stored procedure has been called.
- Throws:
- DataAccessException
 
- 
executeExecute the stored procedure. Subclasses should define a strongly typed execute method (with a meaningful name) that invokes this method, passing in a ParameterMapper that will populate the input map. This allows mapping database specific features since the ParameterMapper has access to the Connection object. The execute method is also responsible for extracting typed values from the output map. Subclass execute methods will often take domain objects as arguments and return values. Alternatively, they can return void.- Parameters:
- inParamMapper- map of input parameters, keyed by name as in parameter declarations. Output parameters need not (but can) be included in this map. It is legal for map entries to be- null, and this will produce the correct behavior using a NULL argument to the stored procedure.
- Returns:
- map of output params, keyed by name as in parameter declarations. Output parameters will appear here, with their values after the stored procedure has been called.
- Throws:
- DataAccessException
 
 
-