Class SynchronousBoundJoin
java.lang.Object
org.eclipse.rdf4j.common.iteration.AbstractCloseableIteration<E>
org.eclipse.rdf4j.common.iteration.LookAheadIteration<T>
org.eclipse.rdf4j.federated.evaluation.concurrent.ParallelExecutorBase<T>
org.eclipse.rdf4j.federated.evaluation.join.JoinExecutorBase<BindingSet>
org.eclipse.rdf4j.federated.evaluation.join.SynchronousJoin
org.eclipse.rdf4j.federated.evaluation.join.SynchronousBoundJoin
- All Implemented Interfaces:
- AutoCloseable,- Runnable,- Iterator<BindingSet>,- CloseableIteration<BindingSet>,- ParallelExecutor<BindingSet>
Execute the nested loop join in a synchronous fashion, using grouped requests, i.e. group bindings into one SPARQL
 request using the UNION operator
- Author:
- Andreas Schwarte
- 
Field SummaryFields inherited from class org.eclipse.rdf4j.federated.evaluation.join.JoinExecutorBasebindings, joinVars, leftIter, rightArgFields inherited from class org.eclipse.rdf4j.federated.evaluation.concurrent.ParallelExecutorBaseevaluationThread, executorId, finished, NEXT_EXECUTOR_ID, queryInfo, rightIter, rightQueue, strategy
- 
Constructor SummaryConstructorsConstructorDescriptionSynchronousBoundJoin(FederationEvalStrategy strategy, CloseableIteration<BindingSet> leftIter, TupleExpr rightArg, BindingSet bindings, QueryInfo queryInfo) 
- 
Method SummaryModifier and TypeMethodDescriptionprotected voidImplementations must implement this method to handle bindings.Methods inherited from class org.eclipse.rdf4j.federated.evaluation.join.JoinExecutorBasegetExecutorType, getJoinVars, handleClose, performExecution, setJoinVarsMethods inherited from class org.eclipse.rdf4j.federated.evaluation.concurrent.ParallelExecutorBaseaddResult, checkTimeout, done, getDisplayId, getId, getNextElement, getQueryInfo, isFinished, run, toss, toStringMethods inherited from class org.eclipse.rdf4j.common.iteration.LookAheadIterationhasNext, next, removeMethods inherited from class org.eclipse.rdf4j.common.iteration.AbstractCloseableIterationclose, isClosedMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface org.eclipse.rdf4j.common.iteration.CloseableIterationstreamMethods inherited from interface java.util.IteratorforEachRemaining
- 
Constructor Details- 
SynchronousBoundJoinpublic SynchronousBoundJoin(FederationEvalStrategy strategy, CloseableIteration<BindingSet> leftIter, TupleExpr rightArg, BindingSet bindings, QueryInfo queryInfo) throws QueryEvaluationException - Throws:
- QueryEvaluationException
 
 
- 
- 
Method Details- 
handleBindingsDescription 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 Note that the implementation must block until the entire join is executed.- Overrides:
- handleBindingsin class- SynchronousJoin
- Throws:
- Exception
 
 
-