Class HashJoinIteration
- java.lang.Object
- 
- org.eclipse.rdf4j.common.iteration.AbstractCloseableIteration<E,X>
- 
- org.eclipse.rdf4j.common.iteration.LookAheadIteration<BindingSet,QueryEvaluationException>
- 
- org.eclipse.rdf4j.query.algebra.evaluation.iterator.HashJoinIteration
 
 
 
- 
- All Implemented Interfaces:
- AutoCloseable,- CloseableIteration<BindingSet,QueryEvaluationException>,- Iteration<BindingSet,QueryEvaluationException>
 - Direct Known Subclasses:
- LimitedSizeHashJoinIteration
 
 public class HashJoinIteration extends LookAheadIteration<BindingSet,QueryEvaluationException> Generic hash join implementation suitable for use by Sail implementations.- Author:
- MJAHale
 
- 
- 
Field SummaryFields Modifier and Type Field Description protected String[]joinAttributes
 - 
Constructor SummaryConstructors Constructor Description HashJoinIteration(EvaluationStrategy strategy, CloseableIteration<BindingSet,QueryEvaluationException> leftIter, Set<String> leftBindingNames, CloseableIteration<BindingSet,QueryEvaluationException> rightIter, Set<String> rightBindingNames, boolean leftJoin)HashJoinIteration(EvaluationStrategy strategy, Join join, BindingSet bindings)HashJoinIteration(EvaluationStrategy strategy, LeftJoin join, BindingSet bindings)HashJoinIteration(EvaluationStrategy strategy, TupleExpr left, TupleExpr right, BindingSet bindings, boolean leftJoin)
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description protected <E> voidadd(Collection<E> col, E value)protected <E> voidaddAll(Collection<E> col, List<E> values)protected <E> voidcloseHashValue(Iterator<E> iter)Utility methods to clear-up in case not using in-memory hash table.protected voiddisposeCache(Iterator<BindingSet> iter)Utility methods to clear-up in case not using in-memory cache.protected voiddisposeHashTable(Map<BindingSetHashKey,List<BindingSet>> map)Utility methods to clear-up in case not using in-memory hash table.protected BindingSetgetNextElement()Gets the next element.protected voidhandleClose()Called byAbstractCloseableIteration.close()when it is called for the first time.protected Map<BindingSetHashKey,List<BindingSet>>makeHashTable(int initialSize)Utility methods to make it easier to inserted custom store dependent mapsprotected List<BindingSet>makeHashValue(int currentMaxListSize)Utility methods to make it easier to inserted custom store dependent listprotected Collection<BindingSet>makeIterationCache(CloseableIteration<BindingSet,QueryEvaluationException> iter)Utility methods to make it easier to inserted custom store dependent listprotected <E> EnextFromCache(Iterator<E> iter)protected voidputHashTableEntry(Map<BindingSetHashKey,List<BindingSet>> nextHashTable, BindingSetHashKey hashKey, List<BindingSet> hashValue, boolean newEntry)- 
Methods inherited from class org.eclipse.rdf4j.common.iteration.LookAheadIterationhasNext, next, remove
 - 
Methods inherited from class org.eclipse.rdf4j.common.iteration.AbstractCloseableIterationclose, isClosed
 
- 
 
- 
- 
- 
Field Detail- 
joinAttributesprotected final String[] joinAttributes 
 
- 
 - 
Constructor Detail- 
HashJoinIterationpublic HashJoinIteration(EvaluationStrategy strategy, Join join, BindingSet bindings) throws QueryEvaluationException - Throws:
- QueryEvaluationException
 
 - 
HashJoinIterationpublic HashJoinIteration(EvaluationStrategy strategy, LeftJoin join, BindingSet bindings) throws QueryEvaluationException - Throws:
- QueryEvaluationException
 
 - 
HashJoinIterationpublic HashJoinIteration(EvaluationStrategy strategy, TupleExpr left, TupleExpr right, BindingSet bindings, boolean leftJoin) throws QueryEvaluationException - Throws:
- QueryEvaluationException
 
 - 
HashJoinIterationpublic HashJoinIteration(EvaluationStrategy strategy, CloseableIteration<BindingSet,QueryEvaluationException> leftIter, Set<String> leftBindingNames, CloseableIteration<BindingSet,QueryEvaluationException> rightIter, Set<String> rightBindingNames, boolean leftJoin) throws QueryEvaluationException - Throws:
- QueryEvaluationException
 
 
- 
 - 
Method Detail- 
getNextElementprotected BindingSet getNextElement() throws QueryEvaluationException Description copied from class:LookAheadIterationGets the next element. Subclasses should implement this method so that it returns the next element.- Specified by:
- getNextElementin class- LookAheadIteration<BindingSet,QueryEvaluationException>
- Returns:
- The next element, or null if no more elements are available.
- Throws:
- QueryEvaluationException
 
 - 
handleCloseprotected void handleClose() throws QueryEvaluationExceptionDescription copied from class:AbstractCloseableIterationCalled byAbstractCloseableIteration.close()when it is called for the first time. This method is only called once on each iteration. By default, this method does nothing.- Overrides:
- handleClosein class- LookAheadIteration<BindingSet,QueryEvaluationException>
- Throws:
- QueryEvaluationException
 
 - 
putHashTableEntryprotected void putHashTableEntry(Map<BindingSetHashKey,List<BindingSet>> nextHashTable, BindingSetHashKey hashKey, List<BindingSet> hashValue, boolean newEntry) throws QueryEvaluationException - Throws:
- QueryEvaluationException
 
 - 
makeIterationCacheprotected Collection<BindingSet> makeIterationCache(CloseableIteration<BindingSet,QueryEvaluationException> iter) Utility methods to make it easier to inserted custom store dependent list- Returns:
- list
 
 - 
makeHashTableprotected Map<BindingSetHashKey,List<BindingSet>> makeHashTable(int initialSize) Utility methods to make it easier to inserted custom store dependent maps- Returns:
- map
 
 - 
makeHashValueprotected List<BindingSet> makeHashValue(int currentMaxListSize) Utility methods to make it easier to inserted custom store dependent list- Returns:
- list
 
 - 
disposeCacheprotected void disposeCache(Iterator<BindingSet> iter) Utility methods to clear-up in case not using in-memory cache.
 - 
disposeHashTableprotected void disposeHashTable(Map<BindingSetHashKey,List<BindingSet>> map) Utility methods to clear-up in case not using in-memory hash table.
 - 
closeHashValueprotected <E> void closeHashValue(Iterator<E> iter) Utility methods to clear-up in case not using in-memory hash table.
 - 
nextFromCacheprotected <E> E nextFromCache(Iterator<E> iter) 
 - 
addprotected <E> void add(Collection<E> col, E value) throws QueryEvaluationException - Throws:
- QueryEvaluationException
 
 - 
addAllprotected <E> void addAll(Collection<E> col, List<E> values) throws QueryEvaluationException - Throws:
- QueryEvaluationException
 
 
- 
 
-