Class SparqlFederationEvalStrategy
java.lang.Object
org.eclipse.rdf4j.query.algebra.evaluation.impl.DefaultEvaluationStrategy
org.eclipse.rdf4j.query.algebra.evaluation.impl.StrictEvaluationStrategy
org.eclipse.rdf4j.federated.evaluation.FederationEvalStrategy
org.eclipse.rdf4j.federated.evaluation.SparqlFederationEvalStrategy
- All Implemented Interfaces:
- EvaluationStrategy,- FederatedServiceResolver,- FederatedServiceResolverClient
Implementation of a federation evaluation strategy which provides some special optimizations for SPARQL (remote)
 endpoints. The most important optimization is to used prepared SPARQL Queries that are already created using Strings.
 
 Joins are executed using ControlledWorkerBindJoin.
 
This implementation uses the SPARQL 1.1 VALUES operator for the bound-join evaluation
s- Author:
- Andreas Schwarte
- 
Field SummaryFields inherited from class org.eclipse.rdf4j.federated.evaluation.FederationEvalStrategycache, executor, federationContextFields inherited from class org.eclipse.rdf4j.query.algebra.evaluation.impl.DefaultEvaluationStrategydataset, serviceResolver, tripleSource
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionevaluateBoundJoinStatementPattern(StatementTupleExpr stmt, List<BindingSet> bindings) Evaluate a bound join at the relevant endpoint, i.e.protected CloseableIteration<BindingSet>evaluateBoundJoinStatementPattern_UNION(StatementTupleExpr stmt, List<BindingSet> bindings) Deprecated, for removal: This API element is subject to removal in a future version.no longer usedevaluateExclusiveGroup(ExclusiveGroup group, BindingSet bindings) evaluateGroupedCheck(CheckStatementPattern stmt, List<BindingSet> bindings) Perform a grouped check at the relevant endpoints, i.e.executeJoin(ControlledWorkerScheduler<BindingSet> joinScheduler, CloseableIteration<BindingSet> leftIter, TupleExpr rightArg, Set<String> joinVars, BindingSet bindings, QueryInfo queryInfo) Execute the join in a separate thread using some join executor.protected CloseableIteration<BindingSet>executeLeftJoin(ControlledWorkerScheduler<BindingSet> joinScheduler, CloseableIteration<BindingSet> leftIter, LeftJoin leftJoin, BindingSet bindings, QueryInfo queryInfo) Execute the left join in a separate thread using some join executor.Methods inherited from class org.eclipse.rdf4j.federated.evaluation.FederationEvalStrategyevaluate, evaluate, evaluate, evaluate, evaluate, evaluateArbitrayLengthPath, evaluateAtStatementSources, evaluateAtStatementSources, evaluateAtStatementSources, evaluateExclusiveTupleExpr, evaluateLeftBoundJoinStatementPattern, evaluateLeftJoin, evaluateNaryUnion, evaluateNJoin, evaluateService, evaluateService, evaluateSingleSourceQuery, evaluateZeroLengthPath, getAccessibleFederationMembers, getMembersFromContext, getStatements, hasStatements, optimize, optimizeExclusiveExpressions, optimizeJoinOrder, performSourceSelection, performSourceSelection, precompile, precompile, prepare, prepare, prepare, prepare, prepare, prepareExclusiveTupleExpr, prepareLeftJoin, prepareNaryUnion, prepareNJoin, propagateServicesMethods inherited from class org.eclipse.rdf4j.query.algebra.evaluation.impl.DefaultEvaluationStrategyevaluate, evaluate, evaluate, getCollectionFactory, getFederatedServiceResolver, getLimit, getQueryEvaluationMode, getService, getVarValue, isReducedOrDistinct, isTrue, isTrue, precompile, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, prepare, setCollectionFactory, setFederatedServiceResolver, setOptimizerPipeline, setQueryEvaluationMode, setTrackResultSize, setTrackTime, supplyBinaryValueEvaluation, supplyUnaryValueEvaluationMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.eclipse.rdf4j.query.algebra.evaluation.EvaluationStrategyisTrackResultSize
- 
Constructor Details- 
SparqlFederationEvalStrategy
 
- 
- 
Method Details- 
evaluateBoundJoinStatementPatternpublic CloseableIteration<BindingSet> evaluateBoundJoinStatementPattern(StatementTupleExpr stmt, List<BindingSet> bindings) throws QueryEvaluationException Description copied from class:FederationEvalStrategyEvaluate a bound join at the relevant endpoint, i.e. i.e. for a group of bindings retrieve results for the bound statement from the relevant endpoints- Specified by:
- evaluateBoundJoinStatementPatternin class- FederationEvalStrategy
- Returns:
- the result iteration
- Throws:
- QueryEvaluationException
 
- 
evaluateBoundJoinStatementPattern_UNION@Deprecated(forRemoval=true) protected CloseableIteration<BindingSet> evaluateBoundJoinStatementPattern_UNION(StatementTupleExpr stmt, List<BindingSet> bindings) throws QueryEvaluationException Deprecated, for removal: This API element is subject to removal in a future version.no longer usedAlternative evaluation implementation using UNION. Nowadays we use a VALUES clause based implementation- Throws:
- QueryEvaluationException
 
- 
evaluateGroupedCheckpublic CloseableIteration<BindingSet> evaluateGroupedCheck(CheckStatementPattern stmt, List<BindingSet> bindings) throws QueryEvaluationException Description copied from class:FederationEvalStrategyPerform a grouped check at the relevant endpoints, i.e. for a group of bindings keep only those for which at least one endpoint provides a result to the bound statement.- Specified by:
- evaluateGroupedCheckin class- FederationEvalStrategy
- Returns:
- the result iteration
- Throws:
- QueryEvaluationException
 
- 
executeJoinpublic CloseableIteration<BindingSet> executeJoin(ControlledWorkerScheduler<BindingSet> joinScheduler, CloseableIteration<BindingSet> leftIter, TupleExpr rightArg, Set<String> joinVars, BindingSet bindings, QueryInfo queryInfo) throws QueryEvaluationException Description copied from class:FederationEvalStrategyExecute the join in a separate thread using some join executor. Join executors are for instance: For endpoint federation use controlled worker bound join, for local federation use controlled worker join. The other operators are there for completeness. UseFederationEvalStrategy.executorto execute the join (it is a runnable).- Specified by:
- executeJoinin class- FederationEvalStrategy
- Returns:
- the result
- Throws:
- QueryEvaluationException
 
- 
executeLeftJoinprotected CloseableIteration<BindingSet> executeLeftJoin(ControlledWorkerScheduler<BindingSet> joinScheduler, CloseableIteration<BindingSet> leftIter, LeftJoin leftJoin, BindingSet bindings, QueryInfo queryInfo) throws QueryEvaluationException Description copied from class:FederationEvalStrategyExecute the left join in a separate thread using some join executor.- Specified by:
- executeLeftJoinin class- FederationEvalStrategy
- Returns:
- the result
- Throws:
- QueryEvaluationException
 
- 
evaluateExclusiveGrouppublic CloseableIteration<BindingSet> evaluateExclusiveGroup(ExclusiveGroup group, BindingSet bindings) throws RepositoryException, MalformedQueryException, QueryEvaluationException - Specified by:
- evaluateExclusiveGroupin class- FederationEvalStrategy
- Throws:
- RepositoryException
- MalformedQueryException
- QueryEvaluationException
 
 
-