Class ResultSet
- java.lang.Object
- 
- org.apache.tinkerpop.gremlin.driver.ResultSet
 
- 
 public final class ResultSet extends Object implements Iterable<Result> AResultSetis returned from the submission of a Gremlin script to the server and represents the results provided by the server. The results from the server are streamed into theResultSetand therefore may not be available immediately. As such,ResultSetprovides access to a a number of functions that help to work with the asynchronous nature of the data streaming back. Data from results is stored in anResultwhich can be used to retrieve the item once it is on the client side. Note that aResultSetis a forward-only stream only so depending on how the methods are called and interacted with, it is possible to return partial bits of the total response (e.g. callingone()followed byall()will make it so that theListof results returned fromall()have oneResultmissing from the total set as it was already retrieved byone(). This class is not thread-safe.- Author:
- Stephen Mallette (http://stephen.genoprime.com)
 
- 
- 
Constructor SummaryConstructors Constructor Description ResultSet(org.apache.tinkerpop.gremlin.driver.ResultQueue resultQueue, ExecutorService executor, CompletableFuture<Void> readCompleted, RequestMessage originalRequestMessage, Host host)
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description CompletableFuture<List<Result>>all()The returnedCompletableFuturecompletes when all reads are complete for this request and the entire result has been accounted for on the client.booleanallItemsAvailable()Determines if all items have been returned to the client.CompletableFuture<Void>allItemsAvailableAsync()Returns a future that will complete when all items have been returned from the server.intgetAvailableItemCount()Gets the number of items available on the client.HostgetHost()RequestMessagegetOriginalRequestMessage()Iterator<Result>iterator()Returns a blocking iterator of the items streaming from the server to the client.Resultone()Get the nextResultfrom the stream, blocking until one is available.CompletableFuture<List<Result>>some(int items)The returnedCompletableFuturecompletes when the number of items specified are available.CompletableFuture<Map<String,Object>>statusAttributes()Returns a future that will complete whenallItemsAvailable()istrueand will contain the attributes from the response.Stream<Result>stream()Stream items with a blocking iterator.- 
Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 - 
Methods inherited from interface java.lang.IterableforEach, spliterator
 
- 
 
- 
- 
- 
Constructor Detail- 
ResultSetpublic ResultSet(org.apache.tinkerpop.gremlin.driver.ResultQueue resultQueue, ExecutorService executor, CompletableFuture<Void> readCompleted, RequestMessage originalRequestMessage, Host host)
 
- 
 - 
Method Detail- 
getOriginalRequestMessagepublic RequestMessage getOriginalRequestMessage() 
 - 
getHostpublic Host getHost() 
 - 
statusAttributespublic CompletableFuture<Map<String,Object>> statusAttributes() Returns a future that will complete whenallItemsAvailable()istrueand will contain the attributes from the response.
 - 
allItemsAvailablepublic boolean allItemsAvailable() Determines if all items have been returned to the client.
 - 
allItemsAvailableAsyncpublic CompletableFuture<Void> allItemsAvailableAsync() Returns a future that will complete when all items have been returned from the server.
 - 
getAvailableItemCountpublic int getAvailableItemCount() Gets the number of items available on the client.
 - 
somepublic CompletableFuture<List<Result>> some(int items) The returnedCompletableFuturecompletes when the number of items specified are available. The number returned will be equal to or less than that number. They will only be less if the stream is completed and there are less than that number specified available.
 - 
allpublic CompletableFuture<List<Result>> all() The returnedCompletableFuturecompletes when all reads are complete for this request and the entire result has been accounted for on the client. While this method is named "all" it really refers to retrieving all remaining items in the set. For large result sets it is preferred to useIteratororStreamoptions, as the results will be held in memory at once.
 - 
iteratorpublic Iterator<Result> iterator() Returns a blocking iterator of the items streaming from the server to the client. ThisIteratorwill consume results as they arrive and leaving theResultSetempty when complete. The returnedIteratordoes not support theIterator.remove()method.
 
- 
 
-