Class QueryJoinOptimizer
java.lang.Object
org.eclipse.rdf4j.query.algebra.evaluation.optimizer.QueryJoinOptimizer
- All Implemented Interfaces:
- QueryOptimizer
A query optimizer that re-orders nested Joins.
- Author:
- Arjohn Kampman, James Leigh
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionprotected classThis can be extended by subclasses to allow for adjustments to the optimization process.
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic intWhen deciding if merge join is the correct approach we will compare the cardinality of the two join arguments, if one is bigger than the other by a factor of MERGE_JOIN_CARDINALITY_SIZE_DIFF_MULTIPLIER then we will not use merge join.protected final EvaluationStatisticsstatic boolean
- 
Constructor SummaryConstructorsConstructorDescriptionQueryJoinOptimizer(EvaluationStatistics statistics) QueryJoinOptimizer(EvaluationStatistics statistics, boolean trackResultSize) QueryJoinOptimizer(EvaluationStatistics statistics, boolean trackResultSize, TripleSource tripleSource) QueryJoinOptimizer(EvaluationStatistics statistics, TripleSource tripleSource) 
- 
Method SummaryModifier and TypeMethodDescriptionvoidoptimize(TupleExpr tupleExpr, Dataset dataset, BindingSet bindings) Applies generally applicable optimizations: path expressions are sorted from more to less specific.
- 
Field Details- 
MERGE_JOIN_CARDINALITY_SIZE_DIFF_MULTIPLIERWhen deciding if merge join is the correct approach we will compare the cardinality of the two join arguments, if one is bigger than the other by a factor of MERGE_JOIN_CARDINALITY_SIZE_DIFF_MULTIPLIER then we will not use merge join. As an example, if the limit is 10 and the left cardinality if 50 000 and the right cardinality is 500 000 then we will use merge join, but if it is 500 001 then we will not.
- 
USE_MERGE_JOIN_FOR_LAST_STATEMENT_PATTERNS_WHEN_CROSS_JOIN
- 
statistics
 
- 
- 
Constructor Details- 
QueryJoinOptimizer
- 
QueryJoinOptimizer
- 
QueryJoinOptimizer
- 
QueryJoinOptimizerpublic QueryJoinOptimizer(EvaluationStatistics statistics, boolean trackResultSize, TripleSource tripleSource) 
 
- 
- 
Method Details- 
optimizeApplies generally applicable optimizations: path expressions are sorted from more to less specific.- Specified by:
- optimizein interface- QueryOptimizer
- Parameters:
- tupleExpr-
 
 
-