Class HashJoin
java.lang.Object
org.eclipse.rdf4j.common.iteration.AbstractCloseableIteration<E,X>
 
org.eclipse.rdf4j.common.iteration.LookAheadIteration<T,QueryEvaluationException>
 
org.eclipse.rdf4j.federated.evaluation.concurrent.ParallelExecutorBase<T>
org.eclipse.rdf4j.federated.evaluation.join.JoinExecutorBase<BindingSet>
org.eclipse.rdf4j.federated.evaluation.join.HashJoin
- All Implemented Interfaces:
- AutoCloseable,- Runnable,- CloseableIteration<BindingSet,,- QueryEvaluationException> - Iteration<BindingSet,,- QueryEvaluationException> - ParallelExecutor<BindingSet>
Operator for a hash join of tuple expressions.
- Since:
- 6.0
- 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, log, NEXT_EXECUTOR_ID, queryInfo, rightIter, rightQueue, strategy
- 
Constructor SummaryConstructorsConstructorDescriptionHashJoin(FederationEvalStrategy strategy, CloseableIteration<BindingSet, QueryEvaluationException> leftIter, TupleExpr rightArg, QueryEvaluationStep rightPrepared, Set<String> joinVars, BindingSet bindings, QueryInfo queryInfo) 
- 
Method SummaryModifier and TypeMethodDescriptionprotected voidImplementations must implement this method to handle bindings.protected voidperformJoin(Collection<BindingSet> leftBlock, Collection<BindingSet> rightBlock, Set<String> joinVariables, Collection<String> freeVariablesRight) Perform the join and add the result to this cursor.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.CloseableIterationstream
- 
Constructor Details- 
HashJoinpublic HashJoin(FederationEvalStrategy strategy, CloseableIteration<BindingSet, QueryEvaluationException> leftIter, TupleExpr rightArg, QueryEvaluationStep rightPrepared, Set<String> joinVars, 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.- Specified by:
- handleBindingsin class- JoinExecutorBase<BindingSet>
- Throws:
- Exception
 
- 
performJoinprotected void performJoin(Collection<BindingSet> leftBlock, Collection<BindingSet> rightBlock, Set<String> joinVariables, Collection<String> freeVariablesRight) Perform the join and add the result to this cursor.See join(Collection, Collection, Set, Collection)andParallelExecutorBase.addResult(CloseableIteration).- Parameters:
- leftBlock-
- rightBlock-
- joinVariables-
- freeVariablesRight-
 
 
-