Class ForwardQueryResult<E>
- java.lang.Object
-
- java.util.AbstractCollection<E>
-
- java.util.AbstractList<E>
-
- org.datanucleus.store.query.AbstractQueryResult<E>
-
- org.datanucleus.store.rdbms.query.AbstractRDBMSQueryResult<E>
-
- org.datanucleus.store.rdbms.query.ForwardQueryResult<E>
-
- All Implemented Interfaces:
java.io.Serializable,java.lang.Iterable<E>,java.util.Collection<E>,java.util.List<E>,org.datanucleus.store.query.QueryResult<E>
public final class ForwardQueryResult<E> extends AbstractRDBMSQueryResult<E> implements java.io.Serializable
Lazy collection results from a Query with the ResultSet in a forward direction. In general the actual result elements are only loaded when accessed with the exception of non-transactional or optimistic contexts that load the elements at initialisation.If the query had a range defined and this was not handled in the datastore query then this QueryResult will skip the unrequired records and just return the range requested.
- See Also:
- Serialized Form
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description private classForwardQueryResult.QueryResultIteratorAn Iterator results of a pm.query.execute().iterator()
-
Field Summary
Fields Modifier and Type Field Description private java.util.Collection<java.lang.Object>candidatesThe candidate list restriction (optional).protected booleanmoreResultSetRowsWhether there are still more rows to be processed in the ResultSet.protected java.util.List<java.lang.Object>resultIdsprotected java.util.List<E>resultObjsThe Result Objects.-
Fields inherited from class org.datanucleus.store.rdbms.query.AbstractRDBMSQueryResult
applyRangeChecks, bulkLoadedMmds, bulkLoadedValueByMemberNumber, closeStatementWithResultSet, fp, rof, rs
-
-
Constructor Summary
Constructors Constructor Description ForwardQueryResult(org.datanucleus.store.query.Query query, ResultObjectFactory<E> rof, java.sql.ResultSet rs, org.datanucleus.FetchPlan fp, java.util.Collection<java.lang.Object> candidates)Constructor of the result from a Query.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description private voidadvanceToEndOfResultSet()Internal method to advance to the end of the ResultSet, populating the resultObjs, and close the ResultSet when complete.voidclose()Method to close the results, making the results unusable thereafter.protected voidcloseResults()Internal method to close the ResultSet.protected voidclosingConnection()Method called to inform the query result that the connection is being closed so perform any required operations now, or rest in peace.booleancontains(java.lang.Object o)Method to check if the specified object is contained in this result.booleancontainsAll(java.util.Collection c)Method to check if all of the specified objects are contained here.booleanequals(java.lang.Object o)Eget(int index)Method to retrieve a particular element from the list.protected intgetSizeUsingMethod()Method to get the size using the "resultSizeMethod".inthashCode()voidinitialise()booleanisEmpty()Accessor for whether there are any results.java.util.Iterator<E>iterator()Accessor for an iterator for the results.java.util.ListIterator<E>listIterator()Accessor for an iterator for the results.protected EnextResultSetElement()Accessor for the next object from the ResultSet.private voidprocessNumberOfResults(int number)Method to advance through the results, processing the specified number of results.java.lang.Object[]toArray()Method to return the results as an array.<T> T[]toArray(T[] a)Method to return the results as an array.protected java.lang.ObjectwriteReplace()Handle serialisation by returning a java.util.ArrayList of all of the results for this query after disconnecting the query which has the consequence of enforcing the load of all objects.-
Methods inherited from class org.datanucleus.store.rdbms.query.AbstractRDBMSQueryResult
disconnect, registerMemberBulkResultSet, setCloseStatementWithResultSet
-
Methods inherited from class org.datanucleus.store.query.AbstractQueryResult
add, add, addAll, addConnectionListener, assertIsOpen, clear, indexOf, isOpen, lastIndexOf, remove, set, size, subList
-
Methods inherited from class java.util.AbstractCollection
addAll, remove, removeAll, retainAll, toString
-
-
-
-
Field Detail
-
moreResultSetRows
protected boolean moreResultSetRows
Whether there are still more rows to be processed in the ResultSet.
-
resultObjs
protected java.util.List<E> resultObjs
The Result Objects.
-
resultIds
protected java.util.List<java.lang.Object> resultIds
-
candidates
private java.util.Collection<java.lang.Object> candidates
The candidate list restriction (optional).
-
-
Constructor Detail
-
ForwardQueryResult
public ForwardQueryResult(org.datanucleus.store.query.Query query, ResultObjectFactory<E> rof, java.sql.ResultSet rs, org.datanucleus.FetchPlan fp, java.util.Collection<java.lang.Object> candidates)Constructor of the result from a Query.- Parameters:
query- The Queryrof- The factory to retrieve results fromrs- The ResultSet from the Query Statementfp- FetchPlancandidates- Candidate elements
-
-
Method Detail
-
initialise
public void initialise() throws java.sql.SQLException- Specified by:
initialisein classAbstractRDBMSQueryResult<E>- Throws:
java.sql.SQLException
-
processNumberOfResults
private void processNumberOfResults(int number)
Method to advance through the results, processing the specified number of results.- Parameters:
number- Number of results (-1 means process all)
-
advanceToEndOfResultSet
private void advanceToEndOfResultSet()
Internal method to advance to the end of the ResultSet, populating the resultObjs, and close the ResultSet when complete.
-
nextResultSetElement
protected E nextResultSetElement()
Accessor for the next object from the ResultSet.- Returns:
- The next element from the ResultSet.
-
closeResults
protected void closeResults()
Internal method to close the ResultSet.- Overrides:
closeResultsin classAbstractRDBMSQueryResult<E>
-
close
public void close()
Method to close the results, making the results unusable thereafter.- Specified by:
closein interfaceorg.datanucleus.store.query.QueryResult<E>- Overrides:
closein classAbstractRDBMSQueryResult<E>
-
closingConnection
protected void closingConnection()
Method called to inform the query result that the connection is being closed so perform any required operations now, or rest in peace.- Specified by:
closingConnectionin classorg.datanucleus.store.query.AbstractQueryResult<E>
-
iterator
public java.util.Iterator<E> iterator()
Accessor for an iterator for the results.
-
listIterator
public java.util.ListIterator<E> listIterator()
Accessor for an iterator for the results.
-
contains
public boolean contains(java.lang.Object o)
Method to check if the specified object is contained in this result.
-
containsAll
public boolean containsAll(java.util.Collection c)
Method to check if all of the specified objects are contained here.
-
equals
public boolean equals(java.lang.Object o)
- Specified by:
equalsin interfacejava.util.Collection<E>- Specified by:
equalsin interfacejava.util.List<E>- Overrides:
equalsin classAbstractRDBMSQueryResult<E>
-
hashCode
public int hashCode()
- Specified by:
hashCodein interfacejava.util.Collection<E>- Specified by:
hashCodein interfacejava.util.List<E>- Overrides:
hashCodein classAbstractRDBMSQueryResult<E>
-
get
public E get(int index)
Method to retrieve a particular element from the list.
-
isEmpty
public boolean isEmpty()
Accessor for whether there are any results.
-
getSizeUsingMethod
protected int getSizeUsingMethod()
Method to get the size using the "resultSizeMethod". This implementation supports "LAST" method. Override this in subclasses to implement other methods.- Overrides:
getSizeUsingMethodin classorg.datanucleus.store.query.AbstractQueryResult<E>- Returns:
- The size
-
toArray
public java.lang.Object[] toArray()
Method to return the results as an array.
-
toArray
public <T> T[] toArray(T[] a)
Method to return the results as an array.
-
writeReplace
protected java.lang.Object writeReplace() throws java.io.ObjectStreamExceptionHandle serialisation by returning a java.util.ArrayList of all of the results for this query after disconnecting the query which has the consequence of enforcing the load of all objects.- Returns:
- The object to serialise
- Throws:
java.io.ObjectStreamException- Thrown if an error occurs
-
-