PSE 2000 Group 4

jobmatch.data
Class ComputerRequestDO

jobmatch.data.TreeLeafDO
  |
  +--jobmatch.data.ComputerRequestDO
Direct Known Subclasses:
OperatingsystemProfileDO, ProgrammingProfileDO, SoftwareProfileDO

public abstract class ComputerRequestDO
extends TreeLeafDO
implements Serializable

Data core class, used to set, retrieve the ComputerRequestDO information.

Since:
jobmatch
Version:
$Revision: 1.6 $
See Also:
Serialized Form

Field Summary
protected static boolean isView
           
static jobmatch.data.RDBColumn MinCapability
           
static jobmatch.data.RDBColumn PrimaryKey
           
static jobmatch.data.RDBTable table
          static final data members name the table and columns for this DO.
 
Fields inherited from class jobmatch.data.TreeLeafDO
isView, LeafNumber, Mandatory, PrimaryKey, Profile, table
 
Constructor Summary
protected ComputerRequestDO()
          Protected constructor.
protected ComputerRequestDO(boolean is_view)
          Protected constructor.
protected ComputerRequestDO(jobmatch.data.ObjectId id)
          Protected constructor used by createExisting(ObjectId) above.
protected ComputerRequestDO(ResultSet rs)
          Protected constructor.
 
Method Summary
protected  void afterAnySet()
           
protected  void beforeAnyGet()
          The developer of a Business Object that derives from this class can override the methods: beforeAnyGet beforeAnySet afterAnySet to handle any general assertions or cleanup needed for get and set methods.
protected  void beforeAnySet()
           
 void commit()
          Inserts/Updates the DO into its table.
 void commit(jobmatch.data.DBTransaction dbt)
          Inserts/Updates the DO into its table.
 void delete()
          Deletes the DO from its table.
 void delete(jobmatch.data.DBTransaction dbt)
          Deletes the DO from its table.
 CompcapabilityDO getMinCapability()
          Get MinCapability of the NewDBTable
protected  String getTableName()
          Return NewDBTable as the name of the table in the database which contains ComputerRequestDO objects.
 boolean isLoaded()
          isLoaded() Returns true if the data for this objects has been retrieved from the database.
 boolean isReadOnly()
          isReadOnly() Returns true if the data for this object has been marked read-only.
 void loadData()
          loadData() Load the fields for the DO from the database.
protected  void makeIdentical(ComputerRequestDO orig)
          makeIdentical() Assigns the DataStruct of an existing DO to this DO.
protected  void modifyDO(jobmatch.data.DBTransaction dbt, boolean delete)
          Modifies the DO within its table.
protected  void okToCommit()
          A stub method for implementing pre-commit assertions for this ComputerRequestDO.
protected  void okToCommitMinCapability(CompcapabilityDO member)
          A stub method for implementing pre-commit assertions for the MinCapability data member.
protected  void okToCommitProfile(ProfileDO member)
          A stub method for implementing pre-commit assertions for the Profile data member.
protected  void okToDelete()
          A stub method for implementing pre-delete assertions for this ComputerRequestDO.
protected  void okToDeleteMinCapability(CompcapabilityDO member)
          A stub method for implementing pre-delete assertions for the MinCapability data member.
protected  void okToDeleteProfile(ProfileDO member)
          A stub method for implementing pre-delete assertions for the Profile data member.
 void setMinCapability(CompcapabilityDO MinCapability)
          Set MinCapability of the NewDBTable
 String toString()
           
 String toString(int indentCount)
           
 
Methods inherited from class jobmatch.data.TreeLeafDO
getLeafNumber, getMandatory, getProfile, makeIdentical, setLeafNumber, setMandatory, setProfile
 

Field Detail

table

public static final jobmatch.data.RDBTable table
static final data members name the table and columns for this DO. By using these members with an instance of the QueryBuilder class, an application can perform straight SQL queries while retaining compile-time checking of table and column usage. Example: List the Cities containing Persons named Bob: Using straight SQL with QueryBuilder: Pro: code runs faster because you create fewer objects Con: code is less clear Vector fields = new Vector(); fields.addElement( AddressDO.City ); QueryBuilder qb = new QueryBuilder( fields ); qb.addWhere( PersonDO.FirstName, "Bob" ); qb.addWhere( PersonDO.PrimaryKey, AddressDO.Person ); RDBRow row; while ( null != ( row = qb.getNextRow() ) ) { String city = row.get( AddressDO.City ).getString(); } Using Query/DO classes: Pro: code is (often) clearer Con: code runs slower because you create more objects PersonQuery pq = new PersonQuery(); pq.setQueryFirstName( "Bob" ); PersonDO[] bobs = pq.getDOArray(); for ( int i = 0; i < bobs.length; i++ ) { AddressQuery aq = new AddressQuery(); aq.setQueryPerson( bobs[i] ); AddressDO addr = aq.getNextDO(); String city = addr.getCity(); }

PrimaryKey

public static final jobmatch.data.RDBColumn PrimaryKey

isView

protected static final boolean isView

MinCapability

public static final jobmatch.data.RDBColumn MinCapability
Constructor Detail

ComputerRequestDO

protected ComputerRequestDO(boolean is_view)
                     throws jobmatch.data.ObjectIdException,
                            jobmatch.data.DatabaseManagerException
Protected constructor. Only derived classes should call it.
Throws:
jobmatch.data.DatabaseManagerException - If a connection to the database cannot be established, etc.
com.lutris.appserver.server.sql.ObjectIdException - If an object id can't be allocated for this object.

ComputerRequestDO

protected ComputerRequestDO()
                     throws jobmatch.data.ObjectIdException,
                            jobmatch.data.DatabaseManagerException
Protected constructor. Only derived classes should call it.
Throws:
jobmatch.data.DatabaseManagerException - If a connection to the database cannot be established, etc.
com.lutris.appserver.server.sql.ObjectIdException - If an object id can't be allocated for this object.

ComputerRequestDO

protected ComputerRequestDO(jobmatch.data.ObjectId id)
                     throws SQLException,
                            jobmatch.data.ObjectIdException,
                            jobmatch.data.DataObjectException,
                            jobmatch.data.DatabaseManagerException
Protected constructor used by createExisting(ObjectId) above. Historical note (delete at will): Formerly, createExisting(ObjectId) invoked the no-args GenericDO ctor, which allocated a new ObjectId. Then, createExisting(ObjectId) would call setOId(id), discarding the newly allocated ObjectId; this resulted in an ObjectId "leak" (needless consumption of oid's.)
Parameters:
id - The ObjectId for the object.
Throws:
jobmatch.data.DataObjectException - If the object is not found in the database.
com.lutris.appserver.server.sql.ObjectIdException - If an object id can't be allocated for this object.
jobmatch.data.DatabaseManagerException - If a connection to the database cannot be established, etc.
SQLException - Should never see this exception since GenericDO.ctor(ObjectId) never accesses the database.

ComputerRequestDO

protected ComputerRequestDO(ResultSet rs)
                     throws SQLException,
                            jobmatch.data.ObjectIdException,
                            jobmatch.data.DataObjectException,
                            jobmatch.data.DatabaseManagerException
Protected constructor.
Parameters:
rs - Result set from which to obtain product data.
Throws:
jobmatch.data.DataObjectException - If the object is not found in the database.
com.lutris.appserver.server.sql.ObjectIdException - If an object id can't be allocated for this object.
jobmatch.data.DatabaseManagerException - If a connection to the database cannot be established, etc.
SQLException - If the database rejects the SQL generated to retrieve data for this object, or if the table contains a bad foreign key, etc.
Method Detail

getTableName

protected String getTableName()
Return NewDBTable as the name of the table in the database which contains ComputerRequestDO objects. This method overrides CoreDO.getTableName() and is used by CoreDO.executeUpdate() during error handling.
Returns:
the database table name
Overrides:
getTableName in class TreeLeafDO
See Also:
CoreDO

isReadOnly

public boolean isReadOnly()
isReadOnly() Returns true if the data for this object has been marked read-only.
Overrides:
isReadOnly in class TreeLeafDO

isLoaded

public boolean isLoaded()
isLoaded() Returns true if the data for this objects has been retrieved from the database.
Overrides:
isLoaded in class TreeLeafDO

loadData

public void loadData()
              throws SQLException,
                     jobmatch.data.ObjectIdException,
                     jobmatch.data.DataObjectException
loadData() Load the fields for the DO from the database.
Throws:
com.lutris.appserver.server.sql.ObjectIdException - If an object id can't be allocated for this object.
jobmatch.data.DataObjectException - If the object is not found in the database.
SQLException - If the database rejects the SQL generated to retrieve data for this object, or if the table contains a bad foreign key, etc.
Overrides:
loadData in class TreeLeafDO

beforeAnyGet

protected void beforeAnyGet()
The developer of a Business Object that derives from this class can override the methods: beforeAnyGet beforeAnySet afterAnySet to handle any general assertions or cleanup needed for get and set methods.
Overrides:
beforeAnyGet in class TreeLeafDO

beforeAnySet

protected void beforeAnySet()
                     throws Exception
Overrides:
beforeAnySet in class TreeLeafDO

afterAnySet

protected void afterAnySet()
Overrides:
afterAnySet in class TreeLeafDO

makeIdentical

protected void makeIdentical(ComputerRequestDO orig)
makeIdentical() Assigns the DataStruct of an existing DO to this DO. Does not duplicate data. Just assigns the reference.
Parameters:
orig - The original DO.

getMinCapability

public CompcapabilityDO getMinCapability()
                                  throws jobmatch.data.DataObjectException
Get MinCapability of the NewDBTable
Returns:
MinCapability of the NewDBTable
Throws:
jobmatch.data.DataObjectException - If the object is not found in the database.

setMinCapability

public void setMinCapability(CompcapabilityDO MinCapability)
                      throws jobmatch.data.DataObjectException
Set MinCapability of the NewDBTable
Parameters:
MinCapability - of the NewDBTable
Throws:
jobmatch.data.DataObjectException - If the object is not found in the database.

toString

public String toString()
Overrides:
toString in class TreeLeafDO

toString

public String toString(int indentCount)
Overrides:
toString in class TreeLeafDO

okToCommit

protected void okToCommit()
                   throws jobmatch.data.RefAssertionException
A stub method for implementing pre-commit assertions for this ComputerRequestDO. Implement this stub to throw an RefAssertionException for cases where this object is not valid for writing to the database.
Overrides:
okToCommit in class TreeLeafDO

okToDelete

protected void okToDelete()
                   throws jobmatch.data.RefAssertionException
A stub method for implementing pre-delete assertions for this ComputerRequestDO. Implement this stub to throw an RefAssertionException for cases where this object is not valid for deletion from the database.
Overrides:
okToDelete in class TreeLeafDO

commit

public void commit()
            throws SQLException,
                   jobmatch.data.DatabaseManagerException,
                   jobmatch.data.DataObjectException,
                   jobmatch.data.RefAssertionException,
                   jobmatch.data.DBRowUpdateException,
                   jobmatch.data.QueryException
Inserts/Updates the DO into its table.
Throws:
com.lutris.appserver.server.sql.DatabaseManagerException - if a Transaction can not be created.
jobmatch.data.RefAssertionException - thrown by okTo method.
SQLException - if any SQL errors occur.
Overrides:
commit in class TreeLeafDO

commit

public void commit(jobmatch.data.DBTransaction dbt)
            throws SQLException,
                   jobmatch.data.DatabaseManagerException,
                   jobmatch.data.DataObjectException,
                   jobmatch.data.RefAssertionException,
                   jobmatch.data.DBRowUpdateException,
                   jobmatch.data.QueryException
Inserts/Updates the DO into its table. The transaction is likely provided by the commit() method of another DO which references this DO.
Parameters:
dbt - The transaction object to use for this operation.
Throws:
com.lutris.appserver.server.sql.DatabaseManagerException - if a Transaction can not be created.
com.lutris.appserver.server.sql.DBRowUpdateException - if a version error occurs.
jobmatch.data.RefAssertionException - thrown by okTo method.
SQLException - if any SQL errors occur.
Overrides:
commit in class TreeLeafDO

delete

public void delete()
            throws SQLException,
                   jobmatch.data.DatabaseManagerException,
                   jobmatch.data.DataObjectException,
                   jobmatch.data.RefAssertionException,
                   jobmatch.data.DBRowUpdateException,
                   jobmatch.data.QueryException
Deletes the DO from its table.
Throws:
com.lutris.appserver.server.sql.DatabaseManagerException - if a Transaction can not be created.
jobmatch.data.RefAssertionException - thrown by okTo method.
SQLException - if any SQL errors occur.
Overrides:
delete in class TreeLeafDO

delete

public void delete(jobmatch.data.DBTransaction dbt)
            throws SQLException,
                   jobmatch.data.DatabaseManagerException,
                   jobmatch.data.DataObjectException,
                   jobmatch.data.RefAssertionException,
                   jobmatch.data.DBRowUpdateException,
                   jobmatch.data.QueryException
Deletes the DO from its table. The transaction is likely provided by the delete() method of another DO which references this DO.
Parameters:
dbt - The transaction object to use for this operation.
Throws:
com.lutris.appserver.server.sql.DatabaseManagerException - if a Transaction can not be created.
com.lutris.appserver.server.sql.DBRowUpdateException - if a version error occurs.
jobmatch.data.RefAssertionException - thrown by okTo method.
SQLException - if any SQL errors occur.
Overrides:
delete in class TreeLeafDO

okToCommitProfile

protected void okToCommitProfile(ProfileDO member)
                          throws jobmatch.data.RefAssertionException
A stub method for implementing pre-commit assertions for the Profile data member. Implement this stub to throw an RefAssertionException for cases where Profile is not valid for writing to the database.
Overrides:
okToCommitProfile in class TreeLeafDO

okToDeleteProfile

protected void okToDeleteProfile(ProfileDO member)
                          throws jobmatch.data.RefAssertionException
A stub method for implementing pre-delete assertions for the Profile data member. Implement this stub to throw an RefAssertionException for cases where Profile is not valid for deletion from the database.
Overrides:
okToDeleteProfile in class TreeLeafDO

okToCommitMinCapability

protected void okToCommitMinCapability(CompcapabilityDO member)
                                throws jobmatch.data.RefAssertionException
A stub method for implementing pre-commit assertions for the MinCapability data member. Implement this stub to throw an RefAssertionException for cases where MinCapability is not valid for writing to the database.

okToDeleteMinCapability

protected void okToDeleteMinCapability(CompcapabilityDO member)
                                throws jobmatch.data.RefAssertionException
A stub method for implementing pre-delete assertions for the MinCapability data member. Implement this stub to throw an RefAssertionException for cases where MinCapability is not valid for deletion from the database.

modifyDO

protected void modifyDO(jobmatch.data.DBTransaction dbt,
                        boolean delete)
                 throws SQLException,
                        jobmatch.data.DatabaseManagerException,
                        jobmatch.data.DataObjectException,
                        jobmatch.data.RefAssertionException,
                        jobmatch.data.DBRowUpdateException,
                        jobmatch.data.QueryException
Modifies the DO within its table. Performs recursive commit/delete on referenced DOs; all operations occur within a single transaction to allow rollback in the event of error. Only the creator of the transaction releases it.
Parameters:
dbt - The transaction object to use for this operation.
delete - True if doing a delete, otherwise doing insert/update.
Throws:
com.lutris.appserver.server.sql.DatabaseManagerException - if a Transaction can not be created.
com.lutris.appserver.server.sql.DBRowUpdateException - if a version error occurs.
jobmatch.data.RefAssertionException - thrown by okTo method.
SQLException - if any SQL errors occur.
Overrides:
modifyDO in class TreeLeafDO

PSE 2000 Group 4