Class RdbmsOperation
- All Implemented Interfaces:
- InitializingBean
- Direct Known Subclasses:
- SqlCall,- SqlOperation
This class and subclasses throw runtime exceptions, defined in the
 org.springframework.dao package (and as thrown by the
 org.springframework.jdbc.core package, which the classes
 in this package use under the hood to perform raw JDBC operations).
 
Subclasses should set SQL and add parameters before invoking the
 compile() method. The order in which parameters are added is
 significant. The appropriate execute or update
 method can then be invoked.
- Author:
- Rod Johnson, Juergen Hoeller
- See Also:
- 
Field SummaryFields
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionvoidEnsures compilation if used in a bean factory.protected booleanReturn whether this operation accepts additional parameters that are given but not actually used.protected voidCheck whether this operation has been compiled already; lazily compile it if not already compiled.final voidcompile()Compile this query.protected abstract voidSubclasses must implement this template method to perform their own compilation.voiddeclareParameter(SqlParameter param) Declare a parameter for this operation.protected List<SqlParameter>Return a list of the declaredSqlParameterobjects.String[]Return the column names of the auto generated keys.Return theJdbcTemplateused by this operation object.intReturn whether statements will return a specific type of ResultSet.getSql()Subclasses can override this to supply dynamic SQL if they wish, but SQL is normally set by calling thesetSql(java.lang.String)method or in a subclass constructor.booleanIs this operation "compiled"? Compilation, as in JDO, means that the operation is fully configured, and ready to use.booleanReturn whether statements should be capable of returning auto-generated keys.booleanReturn whether statements will return updatable ResultSets.protected StringResolve the configured SQL for actual use.voidsetDataSource(DataSource dataSource) Set the JDBCDataSourceto obtain connections from.voidsetFetchSize(int fetchSize) Set the fetch size for this RDBMS operation.voidsetGeneratedKeysColumnNames(String... names) Set the column names of the auto-generated keys.voidsetJdbcTemplate(JdbcTemplate jdbcTemplate) An alternative to the more commonly usedsetDataSource(javax.sql.DataSource)when you want to use the sameJdbcTemplatein multipleRdbmsOperations.voidsetMaxRows(int maxRows) Set the maximum number of rows for this RDBMS operation.voidsetParameters(SqlParameter... parameters) Add one or more declared parameters.voidsetQueryTimeout(int queryTimeout) Set the query timeout for statements that this RDBMS operation executes.voidsetResultSetType(int resultSetType) Set whether to use statements that return a specific type of ResultSet.voidsetReturnGeneratedKeys(boolean returnGeneratedKeys) Set whether prepared statements should be capable of returning auto-generated keys.voidSet the SQL executed by this operation.voidsetTypes(int[] types) Add anonymous parameters, specifying only their SQL types as defined in thejava.sql.Typesclass.voidsetUpdatableResults(boolean updatableResults) Set whether to use statements that are capable of returning updatable ResultSets.protected booleanReturn whether BLOB/CLOB parameters are supported for this kind of operation.protected voidvalidateNamedParameters(Map<String, ?> parameters) Validate the named parameters passed to an execute method based on declared parameters.protected voidvalidateParameters(Object[] parameters) Validate the parameters passed to an execute method based on declared parameters.
- 
Field Details- 
loggerLogger available to subclasses.
 
- 
- 
Constructor Details- 
RdbmsOperationpublic RdbmsOperation()
 
- 
- 
Method Details- 
setJdbcTemplateAn alternative to the more commonly usedsetDataSource(javax.sql.DataSource)when you want to use the sameJdbcTemplatein multipleRdbmsOperations. This is appropriate if theJdbcTemplatehas special configuration such as aSQLExceptionTranslatorto be reused.
- 
getJdbcTemplateReturn theJdbcTemplateused by this operation object.
- 
setDataSourceSet the JDBCDataSourceto obtain connections from.
- 
setFetchSizepublic void setFetchSize(int fetchSize) Set the fetch size for this RDBMS operation. This is important for processing large result sets: Setting this higher than the default value will increase processing speed at the cost of memory consumption; setting this lower can avoid transferring row data that will never be read by the application.Default is -1, indicating to use the driver's default. - See Also:
 
- 
setMaxRowspublic void setMaxRows(int maxRows) Set the maximum number of rows for this RDBMS operation. This is important for processing subsets of large result sets, in order to avoid reading and holding the entire result set in the database or in the JDBC driver.Default is -1, indicating to use the driver's default. - See Also:
 
- 
setQueryTimeoutpublic void setQueryTimeout(int queryTimeout) Set the query timeout for statements that this RDBMS operation executes.Default is -1, indicating to use the JDBC driver's default. Note: Any timeout specified here will be overridden by the remaining transaction timeout when executing within a transaction that has a timeout specified at the transaction level. 
- 
setResultSetTypepublic void setResultSetType(int resultSetType) Set whether to use statements that return a specific type of ResultSet.- Parameters:
- resultSetType- the ResultSet type
- See Also:
 
- 
getResultSetTypepublic int getResultSetType()Return whether statements will return a specific type of ResultSet.
- 
setUpdatableResultspublic void setUpdatableResults(boolean updatableResults) Set whether to use statements that are capable of returning updatable ResultSets.
- 
isUpdatableResultspublic boolean isUpdatableResults()Return whether statements will return updatable ResultSets.
- 
setReturnGeneratedKeyspublic void setReturnGeneratedKeys(boolean returnGeneratedKeys) Set whether prepared statements should be capable of returning auto-generated keys.- See Also:
 
- 
isReturnGeneratedKeyspublic boolean isReturnGeneratedKeys()Return whether statements should be capable of returning auto-generated keys.
- 
setGeneratedKeysColumnNamesSet the column names of the auto-generated keys.
- 
getGeneratedKeysColumnNamesReturn the column names of the auto generated keys.
- 
setSqlSet the SQL executed by this operation.
- 
getSqlSubclasses can override this to supply dynamic SQL if they wish, but SQL is normally set by calling thesetSql(java.lang.String)method or in a subclass constructor.
- 
resolveSqlResolve the configured SQL for actual use.- Returns:
- the SQL (never null)
- Since:
- 5.0
 
- 
setTypesAdd anonymous parameters, specifying only their SQL types as defined in thejava.sql.Typesclass.Parameter ordering is significant. This method is an alternative to the declareParameter(org.springframework.jdbc.core.SqlParameter)method, which should normally be preferred.- Parameters:
- types- array of SQL types as defined in the- java.sql.Typesclass
- Throws:
- InvalidDataAccessApiUsageException- if the operation is already compiled
 
- 
declareParameterDeclare a parameter for this operation.The order in which this method is called is significant when using positional parameters. It is not significant when using named parameters with named SqlParameter objects here; it remains significant when using named parameters in combination with unnamed SqlParameter objects here. - Parameters:
- param- the SqlParameter to add. This will specify SQL type and (optionally) the parameter's name. Note that you typically use the- SqlParameterclass itself here, not any of its subclasses.
- Throws:
- InvalidDataAccessApiUsageException- if the operation is already compiled, and hence cannot be configured further
 
- 
setParametersAdd one or more declared parameters. Used for configuring this operation when used in a bean factory. Each parameter will specify SQL type and (optionally) the parameter's name.- Parameters:
- parameters- an array containing the declared- SqlParameterobjects
- See Also:
- 
- declaredParameters
 
 
- 
getDeclaredParametersReturn a list of the declaredSqlParameterobjects.
- 
afterPropertiesSetpublic void afterPropertiesSet()Ensures compilation if used in a bean factory.- Specified by:
- afterPropertiesSetin interface- InitializingBean
 
- 
compileCompile this query. Ignores subsequent attempts to compile.- Throws:
- InvalidDataAccessApiUsageException- if the object hasn't been correctly initialized, for example if no DataSource has been provided
 
- 
isCompiledpublic boolean isCompiled()Is this operation "compiled"? Compilation, as in JDO, means that the operation is fully configured, and ready to use. The exact meaning of compilation will vary between subclasses.- Returns:
- whether this operation is compiled and ready to use
 
- 
checkCompiledprotected void checkCompiled()Check whether this operation has been compiled already; lazily compile it if not already compiled.Automatically called by validateParameters.- See Also:
 
- 
validateParametersprotected void validateParameters(@Nullable Object[] parameters) throws InvalidDataAccessApiUsageException Validate the parameters passed to an execute method based on declared parameters. Subclasses should invoke this method before everyexecuteQuery()orupdate()method.- Parameters:
- parameters- the parameters supplied (may be- null)
- Throws:
- InvalidDataAccessApiUsageException- if the parameters are invalid
 
- 
validateNamedParametersprotected void validateNamedParameters(@Nullable Map<String, ?> parameters) throws InvalidDataAccessApiUsageExceptionValidate the named parameters passed to an execute method based on declared parameters. Subclasses should invoke this method before everyexecuteQuery()orupdate()method.- Parameters:
- parameters- parameter Map supplied (may be- null)
- Throws:
- InvalidDataAccessApiUsageException- if the parameters are invalid
 
- 
compileInternalSubclasses must implement this template method to perform their own compilation. Invoked after this base class's compilation is complete.Subclasses can assume that SQL and a DataSource have been supplied. - Throws:
- InvalidDataAccessApiUsageException- if the subclass hasn't been properly configured
 
- 
supportsLobParametersprotected boolean supportsLobParameters()Return whether BLOB/CLOB parameters are supported for this kind of operation.The default is true.
- 
allowsUnusedParametersprotected boolean allowsUnusedParameters()Return whether this operation accepts additional parameters that are given but not actually used. Applies in particular to parameter Maps.The default is false.- See Also:
 
 
-