Class FedXConnection
- All Implemented Interfaces:
- AutoCloseable,- SailConnection
FederationEvalStrategy to evaluate provided queries.
 Prior to evaluation various optimizations are performed, see
 FedXOptimizer for further details.
 
 Since 4.0 FedX supports write operations using the supplied WriteStrategy, e.g. by writing to a designated
 federation member. Note: the WriteStrategy is initialized lazily upon first access to a write operation, see
 getWriteStrategyInternal().
 
Implementation notes: - not all methods are implemented as of now
- Author:
- Andreas Schwarte
- See Also:
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionprotected static classA default implementation forAbstractSail.
- 
Field SummaryFields
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionprotected voidaddStatementInternal(Resource subj, IRI pred, Value obj, Resource... contexts) protected voidclearInternal(Resource... contexts) protected voidprotected voidprotected voidprotected CloseableIteration<? extends BindingSet>evaluateInternal(TupleExpr query, Dataset dataset, BindingSet bindings, boolean includeInferred) explain(Explanation.Level level, TupleExpr tupleExpr, Dataset dataset, BindingSet bindings, boolean includeInferred, int timeoutSeconds) Explain how the TupleExpr will be (or has been) executed/evaluated by returning a TupleExpr (which may or may not be the provided TupleExpr) that has gone through zero or more of the stages prior to and also including execution as specified by the provided level.protected CloseableIteration<? extends Resource>protected StringgetNamespaceInternal(String prefix) protected CloseableIteration<? extends Namespace>protected CloseableIteration<? extends Statement>getStatementsInternal(Resource subj, IRI pred, Value obj, boolean includeInferred, Resource... contexts) protected WriteStrategyReturn the initializedwriteStrategy.protected booleanhasStatementInternal(Resource subj, IRI pred, Value obj, boolean includeInferred, Resource[] contexts) protected voidremoveNamespaceInternal(String prefix) protected voidremoveStatementsInternal(Resource subj, IRI pred, Value obj, Resource... contexts) protected voidprotected voidsetNamespaceInternal(String prefix, String name) voidsetTransactionSettings(TransactionSetting... settings) Pass any transaction-specific settings to the SailConnection.protected longsizeInternal(Resource... contexts) protected voidMethods inherited from class org.eclipse.rdf4j.sail.helpers.AbstractSailConnectionaddStatement, addStatement, autoStartTransaction, begin, begin, clear, clearNamespaces, close, commit, endUpdate, endUpdateInternal, evaluate, flush, getContextIDs, getNamespace, getNamespaces, getOwner, getSailBase, getStatements, getStatements, getStatementsInternal, getTransactionIsolation, hasStatement, isActive, isActiveOperation, isOpen, iterationClosed, pendingAdds, prepare, prepareInternal, registerIteration, removeNamespace, removeStatement, removeStatements, rollback, setNamespace, setStatementsAdded, setStatementsRemoved, size, startUpdate, transactionActive, verifyIsActive, verifyIsOpen, waitForOtherOperationsMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.eclipse.rdf4j.sail.SailConnectiongetComparator, getSupportedOrders, prepareQuery
- 
Field Details- 
federation
- 
federationContext
 
- 
- 
Constructor Details- 
FedXConnection- Throws:
- SailException
 
 
- 
- 
Method Details- 
setTransactionSettingsDescription copied from interface:SailConnectionPass any transaction-specific settings to the SailConnection. This method needs to be called before the transaction isstarted.Sail implementations can override this method to receive the transaction settings (to inspect and/or pass them along to any wrapped sail objects). Remember to call super.setTransactionSettings(settings)if you override this method.- Parameters:
- settings- the transaction settings on which the next transaction operates. It may or may not contain the isolation level.
 
- 
evaluateInternalprotected CloseableIteration<? extends BindingSet> evaluateInternal(TupleExpr query, Dataset dataset, BindingSet bindings, boolean includeInferred) throws SailException - Specified by:
- evaluateInternalin class- AbstractSailConnection
- Throws:
- SailException
 
- 
clearInternal- Specified by:
- clearInternalin class- AbstractSailConnection
- Throws:
- SailException
 
- 
clearNamespacesInternal- Specified by:
- clearNamespacesInternalin class- AbstractSailConnection
- Throws:
- SailException
 
- 
closeInternal- Specified by:
- closeInternalin class- AbstractSailConnection
- Throws:
- SailException
 
- 
commitInternal- Specified by:
- commitInternalin class- AbstractSailConnection
- Throws:
- SailException
 
- 
getContextIDsInternal- Specified by:
- getContextIDsInternalin class- AbstractSailConnection
- Throws:
- SailException
 
- 
getNamespaceInternal- Specified by:
- getNamespaceInternalin class- AbstractSailConnection
- Throws:
- SailException
 
- 
getNamespacesInternal- Specified by:
- getNamespacesInternalin class- AbstractSailConnection
- Throws:
- SailException
 
- 
getStatementsInternalprotected CloseableIteration<? extends Statement> getStatementsInternal(Resource subj, IRI pred, Value obj, boolean includeInferred, Resource... contexts) throws SailException - Specified by:
- getStatementsInternalin class- AbstractSailConnection
- Throws:
- SailException
 
- 
hasStatementInternalprotected boolean hasStatementInternal(Resource subj, IRI pred, Value obj, boolean includeInferred, Resource[] contexts) - Overrides:
- hasStatementInternalin class- AbstractSailConnection
 
- 
addStatementInternalprotected void addStatementInternal(Resource subj, IRI pred, Value obj, Resource... contexts) throws SailException - Specified by:
- addStatementInternalin class- AbstractSailConnection
- Throws:
- SailException
 
- 
removeNamespaceInternal- Specified by:
- removeNamespaceInternalin class- AbstractSailConnection
- Throws:
- SailException
 
- 
removeStatementsInternalprotected void removeStatementsInternal(Resource subj, IRI pred, Value obj, Resource... contexts) throws SailException - Specified by:
- removeStatementsInternalin class- AbstractSailConnection
- Throws:
- SailException
 
- 
rollbackInternal- Specified by:
- rollbackInternalin class- AbstractSailConnection
- Throws:
- SailException
 
- 
setNamespaceInternal- Specified by:
- setNamespaceInternalin class- AbstractSailConnection
- Throws:
- SailException
 
- 
sizeInternal- Specified by:
- sizeInternalin class- AbstractSailConnection
- Throws:
- SailException
 
- 
startTransactionInternal- Specified by:
- startTransactionInternalin class- AbstractSailConnection
- Throws:
- SailException
 
- 
getWriteStrategyInternalReturn the initializedwriteStrategy. If this has not been done yet,WriteStrategy#initialize()is returned. This method guarantees lazy initialization upon the first write operation on thisFedXConnectioninstance.- Returns:
- the WriteStrategy
- Throws:
- SailException
 
- 
explainpublic Explanation explain(Explanation.Level level, TupleExpr tupleExpr, Dataset dataset, BindingSet bindings, boolean includeInferred, int timeoutSeconds) Description copied from interface:SailConnectionExplain how the TupleExpr will be (or has been) executed/evaluated by returning a TupleExpr (which may or may not be the provided TupleExpr) that has gone through zero or more of the stages prior to and also including execution as specified by the provided level. This method is used by the Query interface. WARNING: This method is experimental and is subject to change or removal without warning. There is currently only partial support for this method in RDF4J and and UnsupportedOperationException where support is lacking. - Parameters:
- level- the explanation level, eg. OPTIMIZED
- tupleExpr- The tuple expression to evaluate. Mutable.
- dataset- The dataset to use for evaluating the query, null to use the Sail's default dataset.
- bindings- A set of input parameters for the query evaluation. The keys reference variable names that should be bound to the value they map to.
- includeInferred- Indicates whether inferred triples are to be considered in the query result. If false, no inferred statements are returned; if true, inferred statements are returned if available
- timeoutSeconds- for explanations that require execution a timeout can be provided in seconds
- Returns:
- The resulting tuple expression after being run through the specified level
 
 
-