|
|||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object org.springframework.jdbc.object.RdbmsOperation
Root of the JDBC object hierarchy, as described in Chapter 9 of Expert One-On-One J2EE Design and Development by Rod Johnson (Wrox, 2002).
An "RDBMS operation" is a multithreaded, reusable object representing a query, update or stored procedure. An RDBMS operation is not a command, as a command isn't reusable. However, execute methods may take commands as arguments. Subclasses should be Java beans, allowing easy configuration.
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 to perform raw JDBC actions).
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.
org.springframework.dao
,
org.springframework.jdbc.core
Field Summary | |
protected org.apache.commons.logging.Log |
logger
|
Constructor Summary | |
RdbmsOperation()
|
Method Summary | |
void |
afterPropertiesSet()
Ensures compilation if used in a bean factory. |
void |
compile()
Compile this query. |
protected abstract void |
compileInternal()
Subclasses must implement to perform their own compilation. |
void |
declareParameter(SqlParameter param)
Declare a parameter. |
protected java.util.List |
getDeclaredParameters()
Return a list of the declared SqlParameter objects. |
protected JdbcTemplate |
getJdbcTemplate()
Return the JdbcTemplate object used by this object. |
java.lang.String |
getSql()
Subclasses can override this to supply dynamic SQL if they wish, but SQL is normally set by calling the setSql() method or in a subclass constructor. |
boolean |
isCompiled()
Is this operation "compiled"? Compilation, as in JDO, means that the operation is fully configured, and ready to use. |
void |
setDataSource(javax.sql.DataSource dataSource)
Set the JDBC DataSource to obtain connections from. |
void |
setJdbcTemplate(JdbcTemplate jdbcTemplate)
An alternative to the more commonly used setDataSource() when you want to use the same JdbcTemplate in multiple RdbmsOperations. |
void |
setSql(java.lang.String sql)
Set the SQL executed by this operation. |
void |
setTypes(int[] types)
Add anonymous parameters, specifying only their SQL types as defined in the java.sql.Types class. |
protected void |
validateParameters(java.lang.Object[] parameters)
Validate the parameters passed to an execute method based on declared parameters. |
Methods inherited from class java.lang.Object |
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Field Detail |
protected final org.apache.commons.logging.Log logger
Constructor Detail |
public RdbmsOperation()
Method Detail |
public void setDataSource(javax.sql.DataSource dataSource)
public void setJdbcTemplate(JdbcTemplate jdbcTemplate)
jdbcTemplate
- protected JdbcTemplate getJdbcTemplate()
public void setTypes(int[] types) throws InvalidDataAccessApiUsageException
Parameter ordering is significant. This method is an alternative to the declareParameter() method, which should normally be preferred.
types
- array of SQL types as defined in the
java.sql.Types class
InvalidDataAccessApiUsageException
- if the operation is already compiledpublic void declareParameter(SqlParameter param) throws InvalidDataAccessApiUsageException
param
- SqlParameter to add. This will specify SQL type and (optionally)
the parameter's name.
InvalidDataAccessApiUsageException
- if the operation is already compiled,
and hence cannot be configured furtherprotected java.util.List getDeclaredParameters()
public void setSql(java.lang.String sql)
sql
- the SQL executed by this operationpublic java.lang.String getSql()
public void afterPropertiesSet()
afterPropertiesSet
in interface InitializingBean
public boolean isCompiled()
public final void compile() throws InvalidDataAccessApiUsageException
InvalidDataAccessApiUsageException
- if the object hasn't
been correctly initialized, for example if no DataSource has been provided.protected abstract void compileInternal() throws InvalidDataAccessApiUsageException
InvalidDataAccessApiUsageException
- if the subclass
hasn't been properly configured.protected void validateParameters(java.lang.Object[] parameters) throws InvalidDataAccessApiUsageException
parameters
- parameters supplied. May be null.
InvalidDataAccessApiUsageException
- if the parameters are invalid
|
|||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |