Class ServiceJoinIterator
- java.lang.Object
- 
- org.eclipse.rdf4j.common.iteration.AbstractCloseableIteration<E>
- 
- org.eclipse.rdf4j.common.iteration.LookAheadIteration<T>
- 
- org.eclipse.rdf4j.repository.sparql.federation.JoinExecutorBase<BindingSet>
- 
- org.eclipse.rdf4j.query.algebra.evaluation.federation.ServiceJoinIterator
 
 
 
 
- 
- All Implemented Interfaces:
- AutoCloseable,- Iterator<BindingSet>,- CloseableIteration<BindingSet>
 
 public class ServiceJoinIterator extends JoinExecutorBase<BindingSet> Iterator for efficient SERVICE evaluation (vectored). SERVICE is the right handside argument of this join.- Author:
- Andreas Schwarte
 
- 
- 
Field SummaryFields Modifier and Type Field Description protected Serviceserviceprotected EvaluationStrategystrategy- 
Fields inherited from class org.eclipse.rdf4j.repository.sparql.federation.JoinExecutorBasebindings, closed, finished, leftIter, NEXT_JOIN_ID, rightArg, rightIter, rightQueue
 
- 
 - 
Constructor SummaryConstructors Constructor Description ServiceJoinIterator(CloseableIteration<BindingSet> leftIter, Service service, BindingSet bindings, EvaluationStrategy strategy)Construct a service join iteration to use vectored evaluation.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description protected voidhandleBindings()Implementations must implement this method to handle bindings.- 
Methods inherited from class org.eclipse.rdf4j.repository.sparql.federation.JoinExecutorBaseaddResult, done, getNextElement, handleClose, isFinished, run, toss
 - 
Methods inherited from class org.eclipse.rdf4j.common.iteration.LookAheadIterationhasNext, next, remove
 - 
Methods inherited from class org.eclipse.rdf4j.common.iteration.AbstractCloseableIterationclose, isClosed
 - 
Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 - 
Methods inherited from interface org.eclipse.rdf4j.common.iteration.CloseableIterationstream
 - 
Methods inherited from interface java.util.IteratorforEachRemaining
 
- 
 
- 
- 
- 
Field Detail- 
serviceprotected Service service 
 - 
strategyprotected EvaluationStrategy strategy 
 
- 
 - 
Constructor Detail- 
ServiceJoinIteratorpublic ServiceJoinIterator(CloseableIteration<BindingSet> leftIter, Service service, BindingSet bindings, EvaluationStrategy strategy) throws QueryEvaluationException Construct a service join iteration to use vectored evaluation. The constructor automatically starts evaluation.- Parameters:
- leftIter-
- service-
- bindings-
- strategy-
- Throws:
- QueryEvaluationException
 
 
- 
 - 
Method Detail- 
handleBindingsprotected void handleBindings() throws ExceptionDescription copied from class:JoinExecutorBaseImplementations must implement this method to handle bindings. Use the following as a templatewhile (!closed && leftIter.hasNext()) { // your code }and add results to rightQueue. Note that addResult() is implemented synchronized and thus thread safe. In case you can guarantee sequential access, it is also possible to directly access rightQueue- Specified by:
- handleBindingsin class- JoinExecutorBase<BindingSet>
- Throws:
- Exception
 
 
- 
 
-