public class ReadAllQuery extends ObjectLevelReadQuery
Purpose: Concrete class for all read queries involving a collection of objects.
Responsibilities: Return a container of the objects generated by the query. Implements the inheritance feature when dealing with abstract descriptors
| Modifier and Type | Class and Description | 
|---|---|
| static class  | ReadAllQuery.DirectionSpecifies the direction in which the hierarchy is traversed in a
 hierarchical query. | 
DatabaseQuery.ParameterType| Modifier and Type | Field and Description | 
|---|---|
| protected Expression | connectByExpression | 
| protected org.eclipse.persistence.internal.queries.ContainerPolicy | containerPolicyUsed for collection and stream support. | 
| protected ReadAllQuery.Direction | direction | 
| protected java.util.List<Expression> | orderSiblingsByExpressions | 
| protected Expression | startWithExpressionUsed for Oracle HierarchicalQuery support | 
additionalFields, aggregateQueries, batchFetchPolicy, cacheUsage, CheckCacheByExactPrimaryKey, CheckCacheByPrimaryKey, CheckCacheOnly, CheckCacheThenDatabase, concreteSubclassCalls, concreteSubclassJoinedMappingIndexes, concreteSubclassQueries, ConformResultsInUnitOfWork, defaultBuilder, distinctState, DoNotCheckCache, DONT_USE_DISTINCT, fetchGroup, fetchGroupName, inMemoryQueryIndirectionPolicy, isCachedExpressionQuery, isPrePrepared, isReadOnly, isReferenceClassLocked, isResultSetAccessOptimizedQuery, isResultSetAccessOptimizedQueryDefault, isResultSetOptimizedQuery, joinedAttributeManager, loadGroup, lockModeType, NONE, nonFetchJoinAttributeExpressions, OPTIMISTIC, OPTIMISTIC_FORCE_INCREMENT, orderByExpressions, partialAttributeExpressions, PESSIMISTIC_, PESSIMISTIC_FORCE_INCREMENT, PESSIMISTIC_READ, PESSIMISTIC_WRITE, READ, shouldExtendPessimisticLockScope, shouldIncludeData, shouldOuterJoinSubclasses, shouldUseDefaultFetchGroup, shouldUseSerializedObjectPolicy, shouldUseSerializedObjectPolicyDefault, UNCOMPUTED_DISTINCT, unionExpressions, USE_DISTINCT, UseDescriptorSetting, usesResultSetAccessOptimization, waitTimeout, waitTimeoutUnit, WRITEDEFAULT_LOCK_MODE, executionTime, isCacheCheckComplete, LOCK, LOCK_NOWAIT, LOCK_RESULT_PROPERTY, lockingClause, NO_LOCK, prefetchedCacheKeys, referenceClass, referenceClassName, requiresDeferredLocks, shouldBuildNullForNullPk, shouldRefreshIdentityMapResult, shouldRefreshRemoteIdentityMapResult, shouldRegisterResultsInUnitOfWork, shouldUseExclusiveConnection, wasDefaultLockModefetchSize, firstResult, maxResults, maxRows, queryId, queryResultCachingPolicy, temporaryCachedQueryResultsaccessors, allowNativeSQLQuery, argumentFields, argumentParameterTypes, arguments, argumentTypeNames, argumentTypes, argumentValues, BATCH_FETCH_PROPERTY, CascadeAggregateDelete, CascadeAllParts, CascadeByMapping, CascadeDependentParts, cascadePolicy, CascadePrivateParts, descriptor, descriptors, doNotRedirect, executionSession, flushOnExecute, hintString, isCustomQueryUsed, isExecutionClone, isNativeConnectionRequired, isPrepared, isUserDefined, isUserDefinedSQLCall, monitorName, name, NoCascading, nullableArguments, parameterDelimiter, partitioningPolicy, properties, queryMechanism, queryTimeout, queryTimeoutUnit, redirector, session, sessionName, shouldBindAllParameters, shouldCacheStatement, shouldCloneCall, shouldMaintainCache, shouldPrepare, shouldRetrieveBypassCache, shouldStoreBypassCache, shouldUseWrapperPolicy, shouldValidateUpdateCallCacheUse, sourceMapping, translationRow| Constructor and Description | 
|---|
| ReadAllQuery()PUBLIC:
 Return a new read all query. | 
| ReadAllQuery(Call call)PUBLIC:
 Create a read all query with the database call. | 
| ReadAllQuery(java.lang.Class classToRead)PUBLIC:
 Return a new read all query. | 
| ReadAllQuery(java.lang.Class classToRead,
            Call call)PUBLIC:
 Return a new read all query. | 
| ReadAllQuery(java.lang.Class classToRead,
            Expression selectionCriteria)PUBLIC:
 Return a new read all query for the class and the selection criteria. | 
| ReadAllQuery(java.lang.Class classToRead,
            ExpressionBuilder builder)PUBLIC:
 Return a new read all query for the class. | 
| ReadAllQuery(ExpressionBuilder builder)PUBLIC:
 The expression builder should be provide on creation to ensure only one is used. | 
| ReadAllQuery(java.lang.Object exampleObject,
            QueryByExamplePolicy policy)PUBLIC:
 Return a query by example query to find all objects matching the attributes of the example object. | 
| Modifier and Type | Method and Description | 
|---|---|
| void | addAscendingOrdering(java.lang.String queryKeyName)PUBLIC:
 Order the query results by the object's attribute or query key name. | 
| void | cacheResult(java.lang.Object unwrappedOriginal)INTERNAL:
  This method is called by the object builder when building an original. | 
| protected java.lang.Boolean | checkCustomQueryFlag(org.eclipse.persistence.internal.sessions.AbstractSession session,
                    org.eclipse.persistence.internal.sessions.AbstractRecord translationRow)INTERNAL:
 Check and return custom query flag. | 
| protected java.lang.Object | checkEarlyReturnLocal(org.eclipse.persistence.internal.sessions.AbstractSession session,
                     org.eclipse.persistence.internal.sessions.AbstractRecord translationRow)INTERNAL:
 The cache check is done before the prepare as a hit will not require the work to be done. | 
| java.lang.Object | clone()INTERNAL:
 Creates and returns a copy of this query. | 
| protected java.lang.Object | conformResult(java.lang.Object result,
             org.eclipse.persistence.internal.sessions.UnitOfWorkImpl unitOfWork,
             org.eclipse.persistence.internal.sessions.AbstractRecord arguments,
             boolean buildDirectlyFromRows)INTERNAL:
 Conform the result if specified. | 
| boolean | equals(java.lang.Object object)INTERNAL:
 Return if the query is equal to the other. | 
| java.lang.Object | execute(org.eclipse.persistence.internal.sessions.AbstractSession session,
       org.eclipse.persistence.internal.sessions.AbstractRecord row)INTERNAL:
 Execute the query. | 
| protected java.lang.Object | executeObjectLevelReadQuery()INTERNAL:
 Execute the query. | 
| protected java.lang.Object | executeObjectLevelReadQueryFromResultSet()INTERNAL:
 Execute the query building the objects directly from the database result-set. | 
| java.lang.Object | extractRemoteResult(org.eclipse.persistence.internal.sessions.remote.Transporter transporter)INTERNAL:
 Extract the correct query result from the transporter. | 
| Expression | getConnectByExpression()PUBLIC: | 
| org.eclipse.persistence.internal.queries.ContainerPolicy | getContainerPolicy()INTERNAL:
 Return the query's container policy. | 
| protected QueryRedirector | getDefaultRedirector()INTERNAL:
 Returns the specific default redirector for this query type. | 
| ReadAllQuery.Direction | getDirection()PUBLIC: | 
| java.util.List<Expression> | getOrderSiblingsByExpressions()PUBLIC: | 
| protected ObjectLevelReadQuery | getReadQuery()INTERNAL:
 Get custom all read query from query manager. | 
| Expression | getStartWithExpression()PUBLIC: | 
| boolean | hasHierarchicalExpressions()INTERNAL:
 Verify that we have hierarchical query expressions | 
| boolean | isDefaultPropertiesQuery()INTERNAL:
 Return true if the query uses default properties. | 
| boolean | isReadAllQuery()PUBLIC:
 Return if this is a read all query. | 
| protected void | prepare()INTERNAL:
 Prepare the receiver for execution in a session. | 
| protected void | prepareCustomQuery(DatabaseQuery customQuery)INTERNAL:
 Set the properties needed to be cascaded into the custom query. | 
| void | prepareForExecution()INTERNAL:
 Prepare the receiver for execution in a session. | 
| void | prepareFromQuery(DatabaseQuery query)INTERNAL:
 Prepare the query from the prepared query. | 
| protected void | prepareSelectAllRows()INTERNAL:
 Prepare the mechanism. | 
| java.lang.Object | registerResultInUnitOfWork(java.lang.Object result,
                          org.eclipse.persistence.internal.sessions.UnitOfWorkImpl unitOfWork,
                          org.eclipse.persistence.internal.sessions.AbstractRecord arguments,
                          boolean buildDirectlyFromRows)INTERNAL:
 All objects queried via a UnitOfWork get registered here. | 
| java.lang.Object | registerResultSetInUnitOfWork(java.sql.ResultSet resultSet,
                             java.util.Vector fields,
                             org.eclipse.persistence.internal.helper.DatabaseField[] fieldsArray,
                             org.eclipse.persistence.internal.sessions.UnitOfWorkImpl unitOfWork,
                             org.eclipse.persistence.internal.sessions.AbstractRecord arguments)INTERNAL:
 Version of the previous method for ResultSet optimization. | 
| java.lang.Object | remoteExecute()INTERNAL:
 Execute the query through remote session. | 
| java.util.Map | replaceValueHoldersIn(java.lang.Object object,
                     org.eclipse.persistence.internal.sessions.remote.RemoteSessionController controller)INTERNAL:
 replace the value holders in the specified result object(s) | 
| void | setContainerPolicy(org.eclipse.persistence.internal.queries.ContainerPolicy containerPolicy)PUBLIC:
 Set the container policy. | 
| void | setHierarchicalQueryClause(Expression startWith,
                          Expression connectBy,
                          java.util.List<Expression> orderSiblingsExpressions)PUBLIC:
 Set the Hierarchical Query Clause for the query
 Example:
 Expression startWith = builder.get("id").equal(new Integer(100)); //can be any expression which identifies a set of employees
 Expression connectBy = builder.get("managedEmployees"); //indicated the relationship that the hierarchy is based on, must be self-referential
 Vector orderBy = new Vector();
 orderBy.addElement(builder.get("startDate"));
 readAllQuery.setHierarchicalQueryClause(startWith, connectBy, orderBy);
 This query would generate SQL like this:
 SELECT * FROM EMPLOYEE START WITH ID=100 CONNECT BY PRIOR ID = MANAGER_ID ORDER SIBLINGS BY START_DATE | 
| void | setHierarchicalQueryClause(Expression startWith,
                          Expression connectBy,
                          java.util.List<Expression> orderSiblingsExpressions,
                          ReadAllQuery.Direction direction)PUBLIC: Set the Hierarchical Query Clause for the query, specifying the
 hierarchy traversal direction
 
 Example:
 
 Expression startWith = builder.get("id").equal(new Integer(100)); //can
 be any expression which identifies a set of employees  Expression connectBy = builder.get("managedEmployees"); //indicated the relationship that the hierarchy is based on, must be self-referential Vector orderBy = new Vector(); orderBy.addElement(builder.get("startDate")); readAllQuery.setHierarchicalQueryClause(startWith, connectBy, orderBy, Direction.CHILD_TO_PARENT); This query would generate SQL like this: SELECT * FROM EMPLOYEE START WITH ID=100 CONNECT BY ID = PRIOR MANAGER_ID ORDER SIBLINGS BY START_DATE | 
| boolean | supportsResultSetAccessOptimizationOnExecute()INTERNAL:
 Indicates whether the query can use ResultSet optimization. | 
| boolean | supportsResultSetAccessOptimizationOnPrepare()INTERNAL:
 Indicates whether the query can use ResultSet optimization. | 
| void | useCollectionClass(java.lang.Class concreteClass)PUBLIC:
 Configure the mapping to use an instance of the specified container class
 to hold the target objects. | 
| void | useCursoredStream()PUBLIC:
 Use a CursoredStream as the result collection. | 
| void | useCursoredStream(int initialReadSize,
                 int pageSize)PUBLIC:
 Use a CursoredStream as the result collection. | 
| void | useCursoredStream(int initialReadSize,
                 int pageSize,
                 ValueReadQuery sizeQuery)PUBLIC:
 Use a CursoredStream as the result collection. | 
| void | useMapClass(java.lang.Class concreteClass,
           java.lang.String methodName)PUBLIC:
 Configure the query to use an instance of the specified container class
 to hold the result objects. | 
| void | useScrollableCursor()PUBLIC:
 Use a ScrollableCursor as the result collection. | 
| void | useScrollableCursor(int pageSize)PUBLIC:
 Use a ScrollableCursor as the result collection. | 
| void | useScrollableCursor(ScrollableCursorPolicy policy)PUBLIC:
 Use a ScrollableCursor as the result collection. | 
acquireLocks, acquireLocksWithoutWaiting, addAdditionalField, addAdditionalField, addBatchReadAttribute, addBatchReadAttribute, addDescendingOrdering, addJoinedAttribute, addJoinedAttribute, addJoinSelectionFields, addNonFetchJoin, addNonFetchJoinedAttribute, addNonFetchJoinedAttribute, addOrdering, addPartialAttribute, addPartialAttribute, addSelectionFieldsForJoinedExpression, addUnionExpression, buildObject, changeDescriptor, checkCacheOnly, checkDescriptor, checkEarlyReturn, checkForCustomQuery, checkPrepare, checkPrePrepare, clearIsResultSetOptimizedQuery, clearUsesResultSetAccessOptimization, computeBatchReadAttributes, computeBatchReadMappingQueries, computeNestedQueriesForBatchReadExpressions, conformIndividualResult, conformResultsInUnitOfWork, copyFromQuery, deepClone, dontAcquireLocks, dontCheckCache, dontRefreshIdentityMapResult, dontRefreshRemoteIdentityMapResult, dontUseDistinct, except, executeDatabaseQuery, executeInUnitOfWork, extendPessimisticLockScope, getAdditionalFields, getAggregateQueries, getAggregateQuery, getAsOfClause, getBatchFetchPolicy, getBatchObjects, getBatchReadAttributeExpressions, getCacheUsage, getConcreteSubclassCalls, getConcreteSubclassJoinedMappingIndexes, getConcreteSubclassQueries, getDistinctState, getExampleObject, getExecutionFetchGroup, getExecutionFetchGroup, getExpressionBuilder, getFetchGroup, getFetchGroupName, getFetchGroupNonNestedFieldsSet, getFetchGroupNonNestedFieldsSet, getFetchGroupSelectionFields, getFetchGroupSelectionFields, getInMemoryQueryIndirectionPolicy, getInMemoryQueryIndirectionPolicyState, getJoinedAttributeExpressions, getJoinedAttributeManager, getLoadGroup, getLockingClause, getLockModeType, getNonFetchJoinAttributeExpressions, getOrderByExpressions, getPartialAttributeExpressions, getPartialAttributeSelectionFields, getQueryByExamplePolicy, getReferenceClass, getReferenceClassName, getSelectionFields, getUnionExpressions, getWaitTimeout, getWaitTimeoutUnit, hasAdditionalFields, hasAsOfClause, hasBatchReadAttributes, hasDefaultBuilder, hasExecutionFetchGroup, hasFetchGroup, hashCode, hasJoining, hasNonFetchJoinedAttributeExpressions, hasOrderByExpressions, hasPartialAttributeExpressions, hasUnionExpressions, initializeDefaultBuilder, intersect, isAttributeBatchRead, isCachedExpressionQuery, isClonePessimisticLocked, isDefaultLock, isDistinctComputed, isLockQuery, isLockQuery, isObjectLevelReadQuery, isPartialAttribute, isPrePrepared, isPrimaryKeyQuery, isReadOnly, isReferenceClassLocked, isResultSetAccessOptimizedQuery, isResultSetOptimizedQuery, prepareFetchGroup, prepareForRemoteExecution, prepareFromCachedQuery, prepareOutsideUnitOfWork, prepareQuery, prepareResultSetAccessOptimization, prePrepare, recordCloneForPessimisticLocking, refreshIdentityMapResult, refreshRemoteIdentityMapResult, resetDistinct, setAdditionalFields, setAggregateQuery, setAsOfClause, setBatchFetchPolicy, setBatchFetchSize, setBatchFetchType, setBatchObjects, setBatchReadAttributeExpressions, setCacheUsage, setDescriptor, setDistinctState, setEJBQLString, setExampleObject, setExpressionBuilder, setFetchGroup, setFetchGroupName, setInMemoryQueryIndirectionPolicy, setInMemoryQueryIndirectionPolicyState, setIsPrepared, setIsPreparedKeepingSubclassData, setIsPrePrepared, setIsReadOnly, setIsResultSetAccessOptimizedQuery, setIsResultSetOptimizedQuery, setJoinedAttributeExpressions, setJoinedAttributeManager, setLoadGroup, setLockingClause, setLockMode, setLockModeType, setNonFetchJoinAttributeExpressions, setOrderByExpressions, setPartialAttributeExpressions, setQueryByExamplePolicy, setReferenceClass, setReferenceClassName, setSelectionCriteria, setShouldExtendPessimisticLockScope, setShouldFilterDuplicates, setShouldIncludeData, setShouldOuterJoinSubclasses, setShouldUseDefaultFetchGroup, setShouldUseSerializedObjectPolicy, setUnionExpressions, setWaitTimeout, setWaitTimeoutUnit, shouldCheckCache, shouldCheckCacheOnly, shouldCheckDescriptorForCacheUsage, shouldConformResultsInUnitOfWork, shouldDistinctBeUsed, shouldExtendPessimisticLockScope, shouldFilterDuplicates, shouldIncludeData, shouldOuterJoinSubclasses, shouldReadAllMappings, shouldReadMapping, shouldUseDefaultFetchGroup, shouldUseSerializedObjectPolicy, toString, union, useDistinct, usesResultSetAccessOptimizationclonedQueryExecutionComplete, convertClassNamesToClasses, getDataResults, getExecutionTime, getLockMode, getPrefetchedCacheKeys, getQueryPrimaryKey, isAttributeJoined, isCacheCheckComplete, isObjectBuildingQuery, isRegisteringResults, postRegisterIndividualResult, registerIndividualResult, requiresDeferredLocks, setExecutionTime, setPrefetchedCacheKeys, setRequiresDeferredLocks, setShouldBuildNullForNullPk, setShouldRefreshIdentityMapResult, setShouldRefreshRemoteIdentityMapResult, setShouldRegisterResultsInUnitOfWork, setShouldUseExclusiveConnection, setWasDefaultLockMode, shouldBuildNullForNullPk, shouldRefreshIdentityMapResult, shouldRefreshRemoteIdentityMapResult, shouldRegisterResultsInUnitOfWork, shouldUseExclusiveConnection, wasDefaultLockModecacheQueryResults, clearQueryResults, doNotCacheQueryResults, getFetchSize, getFirstResult, getInternalMax, getMaxRows, getQueryId, getQueryResults, getQueryResults, getQueryResults, getQueryResultsCachePolicy, getTemporaryCachedQueryResults, isReadQuery, remoteExecute, setFetchSize, setFirstResult, setInternalMax, setMaxRows, setQueryId, setQueryResults, setQueryResultsCachePolicy, setTemporaryCachedQueryResults, shouldCacheQueryResultsaddArgument, addArgument, addArgument, addArgument, addArgument, addArgument, addArgumentByTypeName, addArgumentValue, addArgumentValues, addCall, addStatement, bindAllParameters, buildArgumentFields, buildSelectionCriteria, cacheStatement, cascadeAllParts, cascadeByMapping, cascadeOnlyDependentParts, cascadePrivateParts, checkPrepare, dontBindAllParameters, dontCacheStatement, dontCascadeParts, dontMaintainCache, getAccessor, getAccessors, getArgumentParameterTypes, getArguments, getArgumentTypeNames, getArgumentTypes, getArgumentValues, getCall, getCascadePolicy, getDatasourceCall, getDatasourceCalls, getDescriptor, getDescriptors, getDomainClassNounName, getDoNotRedirect, getEJBQLString, getExecutionSession, getFlushOnExecute, getHintString, getJPQLString, getMonitorName, getName, getNullableArguments, getParameterDelimiter, getParameterDelimiterChar, getPartitioningPolicy, getProperties, getProperty, getQueryMechanism, getQueryNounName, getQueryTimeout, getQueryTimeoutUnit, getRedirector, getRedirectorForQuery, getSelectionCriteria, getSensorName, getSession, getSessionName, getShouldBindAllParameters, getSourceMapping, getSQLStatement, getSQLString, getSQLStrings, getTranslatedSQLString, getTranslatedSQLStrings, getTranslationRow, hasAccessor, hasArguments, hasNullableArguments, hasProperties, hasQueryMechanism, hasSessionName, ignoreBindAllParameters, ignoreCacheStatement, isCallQuery, isCascadeOfAggregateDelete, isCustomQueryUsed, isCustomSelectionQuery, isDataModifyQuery, isDataReadQuery, isDeleteAllQuery, isDeleteObjectQuery, isDirectReadQuery, isExecutionClone, isExpressionQuery, isInsertObjectQuery, isJPQLCallQuery, isModifyAllQuery, isModifyQuery, isNativeConnectionRequired, isObjectLevelModifyQuery, isPrepared, isReadObjectQuery, isReportQuery, isResultSetMappingQuery, isSQLCallQuery, isUpdateAllQuery, isUpdateObjectQuery, isUserDefined, isUserDefinedSQLCall, isValueReadQuery, isWriteObjectQuery, maintainCache, prepareCall, prepareInternal, redirectQuery, removeProperty, resetMonitorName, retrieveBypassCache, rowFromArguments, setAccessor, setAccessors, setAllowNativeSQLQuery, setArguments, setArgumentTypeNames, setArgumentTypes, setArgumentValues, setCall, setCascadePolicy, setDatasourceCall, setDoNotRedirect, setExecutionSession, setFlushOnExecute, setHintString, setIsCustomQueryUsed, setIsExecutionClone, setIsNativeConnectionRequired, setIsUserDefined, setIsUserDefinedSQLCall, setJPQLString, setName, setNullableArguments, setParameterDelimiter, setPartitioningPolicy, setProperties, setProperty, setQueryMechanism, setQueryTimeout, setQueryTimeoutUnit, setRedirector, setSession, setSessionName, setShouldBindAllParameters, setShouldBindAllParameters, setShouldCacheStatement, setShouldMaintainCache, setShouldPrepare, setShouldRetrieveBypassCache, setShouldStoreBypassCache, setShouldUseWrapperPolicy, setShouldValidateUpdateCallCacheUse, setSourceMapping, setSQLStatement, setSQLString, setTranslationRow, shouldAllowNativeSQLQuery, shouldBindAllParameters, shouldCacheStatement, shouldCascadeAllParts, shouldCascadeByMapping, shouldCascadeOnlyDependentParts, shouldCascadeParts, shouldCascadePrivateParts, shouldCloneCall, shouldIgnoreBindAllParameters, shouldIgnoreCacheStatement, shouldMaintainCache, shouldPrepare, shouldPrepare, shouldRetrieveBypassCache, shouldStoreBypassCache, shouldUseWrapperPolicy, shouldValidateUpdateCallCacheUse, storeBypassCacheprotected org.eclipse.persistence.internal.queries.ContainerPolicy containerPolicy
protected Expression startWithExpression
protected Expression connectByExpression
protected java.util.List<Expression> orderSiblingsByExpressions
protected ReadAllQuery.Direction direction
public ReadAllQuery()
public ReadAllQuery(java.lang.Class classToRead)
public ReadAllQuery(java.lang.Class classToRead,
                    Expression selectionCriteria)
public ReadAllQuery(java.lang.Class classToRead,
                    ExpressionBuilder builder)
public ReadAllQuery(java.lang.Class classToRead,
                    Call call)
public ReadAllQuery(java.lang.Object exampleObject,
                    QueryByExamplePolicy policy)
public ReadAllQuery(ExpressionBuilder builder)
public ReadAllQuery(Call call)
public void addAscendingOrdering(java.lang.String queryKeyName)
public void cacheResult(java.lang.Object unwrappedOriginal)
This method is called by the object builder when building an original. It will cause the original to be cached in the query results if the query is set to do so.
cacheResult in class ReadQueryprotected java.lang.Object checkEarlyReturnLocal(org.eclipse.persistence.internal.sessions.AbstractSession session,
                                                 org.eclipse.persistence.internal.sessions.AbstractRecord translationRow)
checkEarlyReturnLocal in class ObjectLevelReadQueryprotected java.lang.Boolean checkCustomQueryFlag(org.eclipse.persistence.internal.sessions.AbstractSession session,
                                                 org.eclipse.persistence.internal.sessions.AbstractRecord translationRow)
null.
 Called from ObjectLevelReadQuery.checkForCustomQuery(AbstractSession, AbstractRecord) to retrieve custom query flag.checkCustomQueryFlag in class ObjectLevelReadQuerysession - Current session (not used).translationRow - Database record (not used).null.protected ObjectLevelReadQuery getReadQuery()
ObjectLevelReadQuery.checkForCustomQuery(AbstractSession, AbstractRecord) to retrieve custom read query.getReadQuery in class ObjectLevelReadQuerypublic java.lang.Object clone()
clone in class ObjectLevelReadQueryprotected java.lang.Object conformResult(java.lang.Object result,
                                         org.eclipse.persistence.internal.sessions.UnitOfWorkImpl unitOfWork,
                                         org.eclipse.persistence.internal.sessions.AbstractRecord arguments,
                                         boolean buildDirectlyFromRows)
public java.lang.Object execute(org.eclipse.persistence.internal.sessions.AbstractSession session,
                                org.eclipse.persistence.internal.sessions.AbstractRecord row)
                         throws DatabaseException
execute in class ObjectLevelReadQuerysession - - the session in which the receiver will be executed.DatabaseException - - an error has occurred on the databaseprotected java.lang.Object executeObjectLevelReadQuery()
                                                throws DatabaseException
executeObjectLevelReadQuery in class ObjectLevelReadQueryDatabaseException - - an error has occurred on the databaseprotected java.lang.Object executeObjectLevelReadQueryFromResultSet()
                                                             throws DatabaseException
executeObjectLevelReadQueryFromResultSet in class ObjectLevelReadQueryDatabaseException - - an error has occurred on the databasepublic java.lang.Object extractRemoteResult(org.eclipse.persistence.internal.sessions.remote.Transporter transporter)
extractRemoteResult in class DatabaseQuerypublic org.eclipse.persistence.internal.queries.ContainerPolicy getContainerPolicy()
protected QueryRedirector getDefaultRedirector()
getDefaultRedirector in class DatabaseQuerypublic Expression getStartWithExpression()
public Expression getConnectByExpression()
public java.util.List<Expression> getOrderSiblingsByExpressions()
public ReadAllQuery.Direction getDirection()
public boolean hasHierarchicalExpressions()
public boolean isDefaultPropertiesQuery()
isDefaultPropertiesQuery in class ObjectLevelReadQuerypublic boolean equals(java.lang.Object object)
equals in class ObjectLevelReadQuerypublic boolean isReadAllQuery()
isReadAllQuery in class DatabaseQueryprotected void prepare()
                throws QueryException
prepare in class ObjectLevelReadQueryQueryExceptionpublic void prepareFromQuery(DatabaseQuery query)
prepareFromQuery in class ObjectLevelReadQueryprotected void prepareCustomQuery(DatabaseQuery customQuery)
prepareCustomQuery in class ObjectBuildingQuerypublic void prepareForExecution()
                         throws QueryException
prepareForExecution in class ReadQueryQueryExceptionprotected void prepareSelectAllRows()
public java.lang.Object registerResultInUnitOfWork(java.lang.Object result,
                                                   org.eclipse.persistence.internal.sessions.UnitOfWorkImpl unitOfWork,
                                                   org.eclipse.persistence.internal.sessions.AbstractRecord arguments,
                                                   boolean buildDirectlyFromRows)
Involves registering the query result individually and in totality, and hence refreshing / conforming is done here.
registerResultInUnitOfWork in class ObjectLevelReadQueryresult - may be collection (read all) or an object (read one),
 or even a cursor.  If in transaction the shared cache will
 be bypassed, meaning the result may not be originals from the parent
 but raw database rows.unitOfWork - the unitOfWork the result is being registered in.arguments - the original arguments/parameters passed to the query
 execution.  Used by conformingbuildDirectlyFromRows - If in transaction must construct
 a registered result from raw database rows.public java.lang.Object registerResultSetInUnitOfWork(java.sql.ResultSet resultSet,
                                                      java.util.Vector fields,
                                                      org.eclipse.persistence.internal.helper.DatabaseField[] fieldsArray,
                                                      org.eclipse.persistence.internal.sessions.UnitOfWorkImpl unitOfWork,
                                                      org.eclipse.persistence.internal.sessions.AbstractRecord arguments)
                                               throws java.sql.SQLException
java.sql.SQLExceptionpublic java.lang.Object remoteExecute()
remoteExecute in class DatabaseQuerypublic java.util.Map replaceValueHoldersIn(java.lang.Object object,
                                           org.eclipse.persistence.internal.sessions.remote.RemoteSessionController controller)
replaceValueHoldersIn in class DatabaseQuerypublic void setContainerPolicy(org.eclipse.persistence.internal.queries.ContainerPolicy containerPolicy)
public void setHierarchicalQueryClause(Expression startWith, Expression connectBy, java.util.List<Expression> orderSiblingsExpressions)
Example:
Expression startWith = builder.get("id").equal(new Integer(100)); //can be any expression which identifies a set of employees
Expression connectBy = builder.get("managedEmployees"); //indicated the relationship that the hierarchy is based on, must be self-referential
Vector orderBy = new Vector();
orderBy.addElement(builder.get("startDate"));
readAllQuery.setHierarchicalQueryClause(startWith, connectBy, orderBy);
This query would generate SQL like this:
SELECT * FROM EMPLOYEE START WITH ID=100 CONNECT BY PRIOR ID = MANAGER_ID ORDER SIBLINGS BY START_DATE
startWith - Describes the START WITH clause of the query - null if not neededconnectBy - This should be a query key expression which indicates an attribute who's mapping describes the hierarchyorderSiblingsExpressions - Contains expressions which indicate fields to be included in the ORDER SIBLINGS BY clause - null if not requiredpublic void setHierarchicalQueryClause(Expression startWith, Expression connectBy, java.util.List<Expression> orderSiblingsExpressions, ReadAllQuery.Direction direction)
Example:
 Expression startWith = builder.get("id").equal(new Integer(100)); //can
 be any expression which identifies a set of employees 
 Expression connectBy = builder.get("managedEmployees"); //indicated the
 relationship that the hierarchy is based on, must be self-referential 
 Vector orderBy = new Vector(); 
 orderBy.addElement(builder.get("startDate")); 
 readAllQuery.setHierarchicalQueryClause(startWith, connectBy, orderBy,
 Direction.CHILD_TO_PARENT);
 
This query would generate SQL like this:
SELECT * FROM EMPLOYEE START WITH ID=100 CONNECT BY ID = PRIOR MANAGER_ID ORDER SIBLINGS BY START_DATE
startWith - Describes the START WITH clause of the query - null if not
            neededconnectBy - This should be a query key expression which indicates an
            attribute who's mapping describes the hierarchyorderSiblingsExpressions - Contains expressions which indicate fields to be included in
            the ORDER SIBLINGS BY clause - null if not requireddirection - The direction in which the hierarchy is traversed; if not
            specified, CHILD_TO_PARENT is used for OneToOne relationships
            and PARENT_TO_CHILD is used for collectionspublic void useCollectionClass(java.lang.Class concreteClass)
jdk1.2.x: The container class must implement (directly or indirectly) the Collection interface.
jdk1.1.x: The container class must be a subclass of Vector.
public void useCursoredStream()
public void useCursoredStream(int initialReadSize,
                              int pageSize)
initialReadSize - the initial number of objects to readpageSize - the number of objects to read when more objects
 are needed from the databasepublic void useCursoredStream(int initialReadSize,
                              int pageSize,
                              ValueReadQuery sizeQuery)
initialReadSize - the initial number of objects to readpageSize - the number of objects to read when more objects
 are needed from the databasesizeQuery - a query that will return the size of the result set;
 this must be set if an expression is not used (i.e. custom SQL)public void useMapClass(java.lang.Class concreteClass,
                        java.lang.String methodName)
jdk1.2.x: The container class must implement (directly or indirectly) the Map interface.
jdk1.1.x: The container class must be a subclass of Hashtable.
The referenceClass must set before calling this method.
public void useScrollableCursor()
public void useScrollableCursor(int pageSize)
pageSize - the number of elements to be read into a the cursor
 when more elements are needed from the database.public void useScrollableCursor(ScrollableCursorPolicy policy)
policy - the scrollable cursor policy allows for additional result set options.
 Example:ScrollableCursorPolicy policy = new ScrollableCursorPolicy()
policy.setResultSetType(ScrollableCursorPolicy.TYPE_SCROLL_INSENSITIVE);
query.useScrollableCursor(policy);
public boolean supportsResultSetAccessOptimizationOnPrepare()
supportsResultSetAccessOptimizationOnPrepare in class ObjectLevelReadQuerypublic boolean supportsResultSetAccessOptimizationOnExecute()
supportsResultSetAccessOptimizationOnExecute in class ObjectLevelReadQuery