Class FedXConnection
- java.lang.Object
- 
- org.eclipse.rdf4j.sail.helpers.AbstractSailConnection
- 
- org.eclipse.rdf4j.federated.FedXConnection
 
 
- 
- All Implemented Interfaces:
- AutoCloseable,- SailConnection
 
 public class FedXConnection extends AbstractSailConnection An implementation of RepositoryConnection that usesFederationEvalStrategyto evaluate provided queries. Prior to evaluation various optimizations are performed, seeFedXOptimizerfor further details.Since 4.0 FedX supports write operations using the supplied WriteStrategy, e.g. by writing to a designated federation member. Note: theWriteStrategyis initialized lazily upon first access to a write operation, seegetWriteStrategyInternal().Implementation notes: - not all methods are implemented as of now - Author:
- Andreas Schwarte
- See Also:
- FederationEvalStrategy,- WriteStrategy
 
- 
- 
Nested Class SummaryNested Classes Modifier and Type Class Description protected static classFedXConnection.SailBaseDefaultImplA default implementation forAbstractSail.
 - 
Field SummaryFields Modifier and Type Field Description protected FedXfederationprotected FederationContextfederationContext- 
Fields inherited from class org.eclipse.rdf4j.sail.helpers.AbstractSailConnectionconnectionLock, updateLock, useConnectionLock
 
- 
 - 
Constructor SummaryConstructors Constructor Description FedXConnection(FedX federation, FederationContext federationContext)
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description protected voidaddStatementInternal(Resource subj, IRI pred, Value obj, Resource... contexts)protected voidclearInternal(Resource... contexts)protected voidclearNamespacesInternal()protected voidcloseInternal()protected voidcommitInternal()protected CloseableIteration<? extends BindingSet,QueryEvaluationException>evaluateInternal(TupleExpr query, Dataset dataset, BindingSet bindings, boolean includeInferred)Explanationexplain(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,SailException>getContextIDsInternal()protected StringgetNamespaceInternal(String prefix)protected CloseableIteration<? extends Namespace,SailException>getNamespacesInternal()protected CloseableIteration<? extends Statement,SailException>getStatementsInternal(Resource subj, IRI pred, Value obj, boolean includeInferred, Resource... contexts)protected WriteStrategygetWriteStrategyInternal()Return the initializedwriteStrategy.booleanpendingRemovals()Indicates if the Sail has any statement removal operations pending (not yetflushed) for the current transaction.protected voidremoveNamespaceInternal(String prefix)protected voidremoveStatementsInternal(Resource subj, IRI pred, Value obj, Resource... contexts)protected voidrollbackInternal()protected voidsetNamespaceInternal(String prefix, String name)voidsetTransactionSettings(TransactionSetting... settings)Pass any transaction-specific settings to the SailConnection.protected longsizeInternal(Resource... contexts)protected voidstartTransactionInternal()- 
Methods inherited from class org.eclipse.rdf4j.sail.helpers.AbstractSailConnectionaddStatement, addStatement, autoStartTransaction, begin, begin, clear, clearNamespaces, close, commit, endUpdate, endUpdateInternal, evaluate, flush, getContextIDs, getExclusiveConnectionLock, getNamespace, getNamespaces, getSharedConnectionLock, getStatements, getTransactionIsolation, getTransactionLock, hasStatement, hasStatementInternal, isActive, isActiveOperation, isOpen, iterationClosed, pendingAdds, prepare, prepareInternal, registerIteration, removeNamespace, removeStatement, removeStatements, rollback, setNamespace, setStatementsAdded, setStatementsRemoved, size, startUpdate, transactionActive, verifyIsActive, verifyIsOpen
 - 
Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 - 
Methods inherited from interface org.eclipse.rdf4j.sail.SailConnectionprepareQuery
 
- 
 
- 
- 
- 
Field Detail- 
federationprotected final FedX federation 
 - 
federationContextprotected final FederationContext federationContext 
 
- 
 - 
Constructor Detail- 
FedXConnectionpublic FedXConnection(FedX federation, FederationContext federationContext) throws SailException - Throws:
- SailException
 
 
- 
 - 
Method Detail- 
setTransactionSettingspublic void setTransactionSettings(TransactionSetting... settings) Description 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,QueryEvaluationException> evaluateInternal(TupleExpr query, Dataset dataset, BindingSet bindings, boolean includeInferred) throws SailException - Specified by:
- evaluateInternalin class- AbstractSailConnection
- Throws:
- SailException
 
 - 
clearInternalprotected void clearInternal(Resource... contexts) throws SailException - Specified by:
- clearInternalin class- AbstractSailConnection
- Throws:
- SailException
 
 - 
clearNamespacesInternalprotected void clearNamespacesInternal() throws SailException- Specified by:
- clearNamespacesInternalin class- AbstractSailConnection
- Throws:
- SailException
 
 - 
closeInternalprotected void closeInternal() throws SailException- Specified by:
- closeInternalin class- AbstractSailConnection
- Throws:
- SailException
 
 - 
commitInternalprotected void commitInternal() throws SailException- Specified by:
- commitInternalin class- AbstractSailConnection
- Throws:
- SailException
 
 - 
getContextIDsInternalprotected CloseableIteration<? extends Resource,SailException> getContextIDsInternal() throws SailException - Specified by:
- getContextIDsInternalin class- AbstractSailConnection
- Throws:
- SailException
 
 - 
getNamespaceInternalprotected String getNamespaceInternal(String prefix) throws SailException - Specified by:
- getNamespaceInternalin class- AbstractSailConnection
- Throws:
- SailException
 
 - 
getNamespacesInternalprotected CloseableIteration<? extends Namespace,SailException> getNamespacesInternal() throws SailException - Specified by:
- getNamespacesInternalin class- AbstractSailConnection
- Throws:
- SailException
 
 - 
getStatementsInternalprotected CloseableIteration<? extends Statement,SailException> getStatementsInternal(Resource subj, IRI pred, Value obj, boolean includeInferred, Resource... contexts) throws SailException - Specified by:
- getStatementsInternalin class- AbstractSailConnection
- Throws:
- SailException
 
 - 
addStatementInternalprotected void addStatementInternal(Resource subj, IRI pred, Value obj, Resource... contexts) throws SailException - Specified by:
- addStatementInternalin class- AbstractSailConnection
- Throws:
- SailException
 
 - 
removeNamespaceInternalprotected void removeNamespaceInternal(String prefix) throws SailException - 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
 
 - 
rollbackInternalprotected void rollbackInternal() throws SailException- Specified by:
- rollbackInternalin class- AbstractSailConnection
- Throws:
- SailException
 
 - 
setNamespaceInternalprotected void setNamespaceInternal(String prefix, String name) throws SailException - Specified by:
- setNamespaceInternalin class- AbstractSailConnection
- Throws:
- SailException
 
 - 
sizeInternalprotected long sizeInternal(Resource... contexts) throws SailException - Specified by:
- sizeInternalin class- AbstractSailConnection
- Throws:
- SailException
 
 - 
startTransactionInternalprotected void startTransactionInternal() throws SailException- Specified by:
- startTransactionInternalin class- AbstractSailConnection
- Throws:
- SailException
 
 - 
getWriteStrategyInternalprotected WriteStrategy getWriteStrategyInternal() throws SailException Return 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
 
 - 
pendingRemovalspublic boolean pendingRemovals() Description copied from interface:SailConnectionIndicates if the Sail has any statement removal operations pending (not yetflushed) for the current transaction.- Specified by:
- pendingRemovalsin interface- SailConnection
- Overrides:
- pendingRemovalsin class- AbstractSailConnection
- Returns:
- true if any statement removal operations have not yet been flushed, false otherwise.
- See Also:
- SailConnection.flush()
 
 - 
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
 
 
- 
 
-