| 
 | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||
java.lang.Objectorg.hydrateframework.Assembler
public abstract class Assembler
Assembler objects are responsible for extracting the data for a particular object from a row of ResultSet data. A concrete class of Assembler object is needed for object in the data model. The Hydrate code generation will automatically generate assembler classes for each object described in the class definition file. Efficiency is an important consideration in the design of this class. After a query has been executed, the result set is first presented to the assembler class to allow it to determine whether the results have sufficient information to create an object. The location of any attributes in the query that pertain to this assembler will be noted at this stage. As the result set is iterated, this information is used to create or find objects and populate them with data from the query.
| Nested Class Summary | |
|---|---|
| static interface | Assembler.AfterBuildImplement this interface if you need to be called back each time a new object is created during the build process. | 
| static interface | Assembler.DiscriminatorThis interface is used to determine whether an object should be built or not. | 
| static class | Assembler.PrefixMapAn implementation of the map interface that behaves as if it contains a value for any key supplied that is the same as the key but with a specified prefix prepended to it. | 
| static class | Assembler.TestColA Discriminatorimplementation that decides whether or not to 
 build an object based on whether a particular column has a particular value. | 
| static class | Assembler.TestKeyA Discriminatorimplementation for class hierarchies. | 
| Field Summary | |
|---|---|
| static int | BUILD_CHECKDB | 
| static int | BUILD_CHECKMEM | 
| static int | BUILD_CHECKMEMCREATElook in memory, create if not found | 
| static int | BUILD_CHECKMEMDBCREATElook in memory, then in the database, create if not found | 
| static int | BUILD_CHECKMEMDBONLYlook in memory, then in the database for existing object and discard data from query if found | 
| static int | BUILD_CHECKMEMDBREFRESHlook in memory, then in the database and update object from query | 
| static int | BUILD_CHECKMEMONLYlook in memory for an existing object and discard data from query if object is found | 
| static int | BUILD_CHECKMEMREFRESHlook in memory and update from the query (default) | 
| static int | BUILD_CREATEcreate new object | 
| static int | BUILD_NOCHECKdo nothing at all | 
| static int | BUILD_REFRESH | 
| protected  boolean | m_autoFixup | 
| protected  int | m_bldType | 
|  java.util.Map | m_columns | 
| protected  java.lang.Object | m_lastBuilt | 
| protected  java.lang.Object[] | m_lastBuiltArray | 
| protected static org.apache.commons.logging.Log | m_log | 
| protected  java.util.Set<java.lang.String> | m_usedColumns | 
| Constructor Summary | |
|---|---|
| Assembler(ObjectContext ctx,
          java.lang.String name,
          java.lang.Class<java.lang.Object> cls,
          ObjectFactory fact,
          KeyAssembler kb,
          java.util.Map columns,
          Assembler.Discriminator incl,
          int buildType,
          boolean autoFixup)The constructor sets the class type to be built and the factory to do the job | |
| Method Summary | |
|---|---|
|  java.lang.Object | buildOneObject(java.sql.ResultSet rs)This method instructs this assembler to try to build one object of the class implied by the assembler's concrete class from the current row of the results set. | 
| abstract  void | delete(java.lang.Object obj,
       NamedParameterStatement stmt,
       java.lang.Class keyClass)This method is overridden by class specific implementations of the assembler to use the results set retrieved from the given statement to delete this object's database representation. | 
|  java.lang.Object | getBuiltObject()Get the object that this assembler, or assemblers have just built or null if none has been built yet. | 
|  java.lang.Object[] | getBuiltObjects()If mroe than one assembler is active in a particular query, more than one object may be returned. | 
|  java.lang.Class<java.lang.Object> | getClassToBuild()Returns a class object that represents the interface of the object that will be built by this assembler. | 
|  java.util.Map | getColumns()Return the map that is owned by this assembler to map attribute names into column names. | 
|  ObjectContext | getContext() | 
|  ObjectFactory | getFactory()Returns the factory object that should be used to construct instances of the object built by this assembler | 
|  java.sql.ResultSet | getInsertResultSet(java.lang.Object obj,
                   NamedParameterStatement stmt)This is a helper method that is used to create a results set that can be used to insert objects through this assembler into a database. | 
|  KeyAssembler | getKeyAssembler()Return the KeyAssembler used to build the object's key from the query | 
|  java.lang.String | getName()Return the name of the assembler. | 
|  java.sql.ResultSet | getResultSet()Return the ResultSetobject that was used in preparing the
 assembler. | 
|  NamedParameterStatement | getStatement(RequestContext rc)Get the default query. | 
|  java.sql.ResultSet | getUpdateResultSet(java.lang.Object obj,
                   NamedParameterStatement stmt,
                   java.lang.Class keyCls)This is a helper method that is used to create a results set that can be used to update objects through this assembler into a database. | 
| protected abstract  boolean | initObject(java.lang.Object oo,
           ObjectKey key)Initialize the object now with values read from the query. | 
| abstract  void | insert(java.lang.Object obj,
       NamedParameterStatement stmt)This method is overridden by class specific implementations of the assembler to write the internals of a given business object to the 'forUpdate' results set retrieved from the given statement, ready for creating a new object in the database. | 
| static java.lang.String | mapColumns(java.util.Map columns,
           java.lang.String value)Static method to map the attribute name of an object to the column name of the query. | 
|  java.lang.String | mapColumns(java.lang.String value)Map the attribute name of an object to the column name of the query. | 
|  void | postCreate(java.sql.ResultSet rs,
           java.lang.Object o,
           boolean isNew)A function that is called after an object has been built by this assembler. | 
|  boolean | prepareToProcessResults(java.sql.ResultSet rs,
                        java.sql.Statement stmt,
                        boolean forUpdate)This method is called after running the SQL statement, but before starting to iterate through the restuls set. | 
|  void | setConnection(java.sql.Connection conn)Establish the connection that is being used with this assembler. | 
| abstract  void | setLink(java.lang.String linkName,
        Assembler other)This method is used to establish a link between assemblers during the build process. | 
|  void | setPostBuild(Assembler.AfterBuild pb)Register a class to be called back each time a new object is created. | 
|  boolean | shouldBuild(java.sql.ResultSet rs)Determine if we should build an object or not, based on the content of of the current QueryResults | 
| protected  boolean | shouldInitExisting() | 
|  void | startNewRow()This method must be called on each assembler each time anew row is started in the results set. | 
| abstract  void | update(java.lang.Object obj,
       NamedParameterStatement stmt,
       java.lang.Class keyClass)This method is overridden by class specific implementations of the assembler to write the internals of a given business object to the 'forUpdate' results set retrieved from the given statement, ready for updating an existing object in the database. | 
| Methods inherited from class java.lang.Object | 
|---|
| clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait | 
| Field Detail | 
|---|
protected static final org.apache.commons.logging.Log m_log
public static final int BUILD_NOCHECK
public static final int BUILD_CHECKMEMONLY
public static final int BUILD_CHECKMEMREFRESH
public static final int BUILD_CHECKMEMDBONLY
public static final int BUILD_CHECKMEMDBREFRESH
public static final int BUILD_CHECKMEMCREATE
public static final int BUILD_CHECKMEMDBCREATE
public static final int BUILD_CREATE
public static final int BUILD_REFRESH
public static final int BUILD_CHECKDB
public static final int BUILD_CHECKMEM
protected int m_bldType
protected boolean m_autoFixup
public java.util.Map m_columns
protected java.util.Set<java.lang.String> m_usedColumns
protected java.lang.Object[] m_lastBuiltArray
protected java.lang.Object m_lastBuilt
| Constructor Detail | 
|---|
public Assembler(ObjectContext ctx,
                 java.lang.String name,
                 java.lang.Class<java.lang.Object> cls,
                 ObjectFactory fact,
                 KeyAssembler kb,
                 java.util.Map columns,
                 Assembler.Discriminator incl,
                 int buildType,
                 boolean autoFixup)
ctx - the Object context into which this assembler will build objectsname - the name of the assembler - this is used to distinguish two 
 assemblers of the same class in the same query.cls - The class object that represents the interface of the business 
 object that will be built by this assembler.fact - The object factory that determines the concrete class that 
 will be constructed that supports the 'cls' interfacekb - the KeyAssembler determines which key is used to identify the
 objectcolumns - a map that maps attribute names in the object to column
 names in the queryincl - an implementation of this interface determines whether the
 assembler should build an object from the current row.buildType - one of the BUILD_... valuesautoFixup - determines whether this Assembler should attempt to automatically
 resolve foreign key references.  If such a foreign key is read from the results
 of a query, the assembler has enough information to create an empty object (or find
 an existing one in memory) with the key set to the value of the foreign key from 
 the query, and link it up to the object whose foreign key it was.  However, this
 only works for many-to-one relationships and when using the alternative approach of explicitly
 naming the links as part of a mapped query, would end up doing the link-up twice.  This
 value should be set to true for builders that are using with non-MappedStatements.| Method Detail | 
|---|
public KeyAssembler getKeyAssembler()
public java.lang.String getName()
public java.lang.String mapColumns(java.lang.String value)
Name of a class might be represented
 in the query with the field PERSON_NAME.  In this case a
 call to this method with the attribute name would return
 PERSON_NAME.  Calling the method twice with the same value
 in the same build session returns null.  This feature means that if a
 column is mapped into the object's key, it is not read again as an 
 attribute (since the key will have already populated that attribute).
 This was done for performance reasons.
value - the attribute name to be mapped to a column name
public static java.lang.String mapColumns(java.util.Map columns,
                                          java.lang.String value)
Name of a class might be represented
 in the query with the field PERSON_NAME.  In this case a
 call to this method with the attribute name would return
 PERSON_NAME.
columns - the map to use if this is null, the given value is returned unchanged.value - the attribute name to be mapped to a column name
public java.util.Map getColumns()
public void setConnection(java.sql.Connection conn)
conn - 
public abstract void setLink(java.lang.String linkName,
                             Assembler other)
AssemblerLink implementation.  This
 method is called while the query map is being set up to initialize
 these variables.
public void setPostBuild(Assembler.AfterBuild pb)
pb - the object to be called which must support the Assembler.AfterBuild interface
public boolean prepareToProcessResults(java.sql.ResultSet rs,
                                       java.sql.Statement stmt,
                                       boolean forUpdate)
rs - the results set that was returned from executing the statement.forUpdate - true if this method is being called with a query that 
 will be used to update a database.public java.sql.ResultSet getResultSet()
ResultSet object that was used in preparing the
 assembler.
ResultSet object
public java.sql.ResultSet getUpdateResultSet(java.lang.Object obj,
                                             NamedParameterStatement stmt,
                                             java.lang.Class keyCls)
                                      throws SaveException
obj - the object that is to be updatedstmt - the statement that will be used to update the object.  This
 statement must be compatible with the object to be updated and the specified
 key type.  In other words, the statement must be updateable and the column names 
 produced by it
 must match the attributes of the given object.keyCls - the class of key that will be used to identify the record
 to update in the underlying database.  The statement must support
 constraints that match the attributes of the key class.
SaveException
public java.sql.ResultSet getInsertResultSet(java.lang.Object obj,
                                             NamedParameterStatement stmt)
                                      throws SaveException
obj - the object that is to be updatedstmt - the statement that will be used to update the object.  This
 statement must be compatible with the object to be updated and the specified
 key type.  In other words, the statement must be updateable and the column names 
 produced by it must match the attributes of the given object.
SaveExceptionpublic java.lang.Class<java.lang.Object> getClassToBuild()
public ObjectFactory getFactory()
public void startNewRow()
public final boolean shouldBuild(java.sql.ResultSet rs)
QueryResults
public java.lang.Object buildOneObject(java.sql.ResultSet rs)
                                throws SaveException
setPostBuild(org.hydrateframework.Assembler.AfterBuild) method to catch new objects as they
 are created.
rs - the results set that is being read.  This must match the results
 set that was passed in when prepareToProcessResults(java.sql.ResultSet, java.sql.Statement, boolean) was called.
SaveException
protected abstract boolean initObject(java.lang.Object oo,
                                      ObjectKey key)
                               throws SaveException
oo - the object to be initialized
SaveException
public NamedParameterStatement getStatement(RequestContext rc)
                                     throws SaveException
rc - the request context that might have the required query in cache
SaveExceptionprotected boolean shouldInitExisting()
public ObjectContext getContext()
public java.lang.Object getBuiltObject()
AssemblerLink
getBuiltObject in interface AssemblerLinkpublic java.lang.Object[] getBuiltObjects()
AssemblerLink
getBuiltObjects in interface AssemblerLink
public void postCreate(java.sql.ResultSet rs,
                       java.lang.Object o,
                       boolean isNew)
Assembler.AfterBuild listener that the
 object the object has been created
rs - the ResultSet being reado - the object that has just been builtisNew - true if this is a newly created object, false if it was read
 from an index.
public abstract void insert(java.lang.Object obj,
                            NamedParameterStatement stmt)
                     throws SaveException
obj - the object to be insertedstmt - the statement to use to insert the object.  The statement must be
 compatible with the object to be updated in that its columns must match
 the attributes of the object.
SaveException
public abstract void update(java.lang.Object obj,
                            NamedParameterStatement stmt,
                            java.lang.Class keyClass)
                     throws SaveException
obj - the object to be updatedstmt - the statement to use to update the object.  The statement must be
 compatible with the object to be updated in that its columns must match
 the attributes of the object.keyClass - the key class to use to identify the object in the database.  The
 statement must support constraints that match the attributes of the key class.
SaveException
public abstract void delete(java.lang.Object obj,
                            NamedParameterStatement stmt,
                            java.lang.Class keyClass)
                     throws SaveException
obj - the object to be deletedstmt - the statement to use to delete the object.keyClass - the key class to use to identify the object in the database.  The
 statement must support constraints that match the attributes of the key class.
SaveException| 
 | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||