Package org.eclipse.rdf4j.sail.base
Class SailSourceConnection
- java.lang.Object
- 
- org.eclipse.rdf4j.sail.helpers.AbstractSailConnection
- 
- org.eclipse.rdf4j.sail.helpers.AbstractNotifyingSailConnection
- 
- org.eclipse.rdf4j.sail.base.SailSourceConnection
 
 
 
- 
- All Implemented Interfaces:
- AutoCloseable,- FederatedServiceResolverClient,- InferencerConnection,- NotifyingSailConnection,- SailConnection
 - Direct Known Subclasses:
- ExtensibleStoreConnection,- LmdbStoreConnection,- MemoryStoreConnection,- NativeStoreConnection
 
 public abstract class SailSourceConnection extends AbstractNotifyingSailConnection implements InferencerConnection, FederatedServiceResolverClient ASailConnectionimplementation that is based on anSailStore.- Author:
- James Leigh
 
- 
- 
Field Summary- 
Fields inherited from class org.eclipse.rdf4j.sail.helpers.AbstractSailConnectionconnectionLock, updateLock, useConnectionLock
 
- 
 - 
Constructor SummaryConstructors Modifier Constructor Description protectedSailSourceConnection(AbstractSail sail, SailStore store, EvaluationStrategyFactory evalStratFactory)Creates a newSailConnection, using the givenSailStoreto manage the state.protectedSailSourceConnection(AbstractSail sail, SailStore store, FederatedServiceResolver resolver)Creates a newSailConnection, using the givenSailStoreto manage the state.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description booleanaddInferredStatement(Resource subj, IRI pred, Value obj, Resource... contexts)Adds an inferred statement to a specific context.voidaddStatement(UpdateContext op, Resource subj, IRI pred, Value obj, Resource... contexts)The default implementation buffers added statements until the update operation is complete.voidclearInferred(Resource... contexts)Removes all inferred statements from the specified/all contexts.protected voidclearInternal(Resource... contexts)protected voidclearNamespacesInternal()protected voidcloseInternal()protected voidcommitInternal()protected voidendUpdateInternal(UpdateContext op)protected CloseableIteration<? extends BindingSet,QueryEvaluationException>evaluateInternal(TupleExpr tupleExpr, 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.voidflushUpdates()Flushes any pending updates to be processed and the resulting changes to be reported to registeredSailConnectionListeners.protected CloseableIteration<? extends Resource,SailException>getContextIDsInternal()protected EvaluationStrategygetEvaluationStrategy(Dataset dataset, TripleSource tripleSource)FederatedServiceResolvergetFederatedServiceResolver()Returns theFederatedServiceResolverbeing used.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 voidprepareInternal()booleanremoveInferredStatement(Resource subj, IRI pred, Value obj, Resource... contexts)Removes an inferred statement from a specific context.protected voidremoveNamespaceInternal(String prefix)voidremoveStatement(UpdateContext op, Resource subj, IRI pred, Value obj, Resource... contexts)The default implementation buffers removed statements until the update operation is complete.protected voidrollbackInternal()voidsetFederatedServiceResolver(FederatedServiceResolver resolver)Sets theFederatedServiceResolverto use.protected voidsetNamespaceInternal(String prefix, String name)protected longsizeInternal(Resource... contexts)protected voidstartTransactionInternal()voidstartUpdate(UpdateContext op)Signals the start of an update operation.- 
Methods inherited from class org.eclipse.rdf4j.sail.helpers.AbstractNotifyingSailConnectionaddConnectionListener, hasConnectionListeners, notifyStatementAdded, notifyStatementRemoved, removeConnectionListener
 - 
Methods inherited from class org.eclipse.rdf4j.sail.helpers.AbstractSailConnectionaddStatement, addStatementInternal, autoStartTransaction, begin, begin, clear, clearNamespaces, close, commit, endUpdate, evaluate, flush, getContextIDs, getExclusiveConnectionLock, getNamespace, getNamespaces, getSharedConnectionLock, getStatements, getTransactionIsolation, getTransactionLock, hasStatement, hasStatementInternal, isActive, isActiveOperation, isOpen, iterationClosed, pendingAdds, pendingRemovals, prepare, registerIteration, removeNamespace, removeStatements, removeStatementsInternal, rollback, setNamespace, setStatementsAdded, setStatementsRemoved, size, 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.NotifyingSailConnectionaddConnectionListener, removeConnectionListener
 - 
Methods inherited from interface org.eclipse.rdf4j.sail.SailConnectionaddStatement, begin, begin, clear, clearNamespaces, close, commit, endUpdate, evaluate, flush, getContextIDs, getNamespace, getNamespaces, getStatements, hasStatement, isActive, isOpen, pendingRemovals, prepare, prepareQuery, removeNamespace, removeStatements, rollback, setNamespace, setTransactionSettings, size
 
- 
 
- 
- 
- 
Constructor Detail- 
SailSourceConnectionprotected SailSourceConnection(AbstractSail sail, SailStore store, FederatedServiceResolver resolver) Creates a newSailConnection, using the givenSailStoreto manage the state.- Parameters:
- sail-
- store-
- resolver- the FederatedServiceResolver to use with the- default EvaluationStrategy.
 
 - 
SailSourceConnectionprotected SailSourceConnection(AbstractSail sail, SailStore store, EvaluationStrategyFactory evalStratFactory) Creates a newSailConnection, using the givenSailStoreto manage the state.- Parameters:
- sail-
- store-
- evalStratFactory- the- EvaluationStrategyFactoryto use.
 
 
- 
 - 
Method Detail- 
getFederatedServiceResolverpublic FederatedServiceResolver getFederatedServiceResolver() Returns theFederatedServiceResolverbeing used.- Returns:
- null if a custom EvaluationStrategyFactoryis being used.
 
 - 
setFederatedServiceResolverpublic void setFederatedServiceResolver(FederatedServiceResolver resolver) Sets theFederatedServiceResolverto use. If a customEvaluationStrategyFactoryis being used then this only has an effect if it implementsFederatedServiceResolverClient.- Specified by:
- setFederatedServiceResolverin interface- FederatedServiceResolverClient
- Parameters:
- resolver- The resolver to use.
 
 - 
getEvaluationStrategyprotected EvaluationStrategy getEvaluationStrategy(Dataset dataset, TripleSource tripleSource) 
 - 
evaluateInternalprotected CloseableIteration<? extends BindingSet,QueryEvaluationException> evaluateInternal(TupleExpr tupleExpr, Dataset dataset, BindingSet bindings, boolean includeInferred) throws SailException - Specified by:
- evaluateInternalin class- AbstractSailConnection
- 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. - Specified by:
- explainin interface- SailConnection
- 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
 
 - 
closeInternalprotected void closeInternal() throws SailException- Specified by:
- closeInternalin class- AbstractSailConnection
- Throws:
- SailException
 
 - 
getContextIDsInternalprotected CloseableIteration<? extends Resource,SailException> getContextIDsInternal() throws SailException - Specified by:
- getContextIDsInternalin 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
 
 - 
sizeInternalprotected long sizeInternal(Resource... contexts) throws SailException - Specified by:
- sizeInternalin class- AbstractSailConnection
- Throws:
- SailException
 
 - 
getNamespacesInternalprotected CloseableIteration<? extends Namespace,SailException> getNamespacesInternal() throws SailException - Specified by:
- getNamespacesInternalin class- AbstractSailConnection
- Throws:
- SailException
 
 - 
getNamespaceInternalprotected String getNamespaceInternal(String prefix) throws SailException - Specified by:
- getNamespaceInternalin class- AbstractSailConnection
- Throws:
- SailException
 
 - 
startTransactionInternalprotected void startTransactionInternal() throws SailException- Specified by:
- startTransactionInternalin class- AbstractSailConnection
- Throws:
- SailException
 
 - 
prepareInternalprotected void prepareInternal() throws SailException- Overrides:
- prepareInternalin class- AbstractSailConnection
- Throws:
- SailException
 
 - 
commitInternalprotected void commitInternal() throws SailException- Specified by:
- commitInternalin class- AbstractSailConnection
- Throws:
- SailException
 
 - 
rollbackInternalprotected void rollbackInternal() throws SailException- Specified by:
- rollbackInternalin class- AbstractSailConnection
- Throws:
- SailException
 
 - 
startUpdatepublic void startUpdate(UpdateContext op) throws SailException Description copied from interface:SailConnectionSignals the start of an update operation. The givenopmaybe passed to subsequentSailConnection.addStatement(UpdateContext, Resource, IRI, Value, Resource...)orSailConnection.removeStatement(UpdateContext, Resource, IRI, Value, Resource...)calls beforeSailConnection.endUpdate(UpdateContext)is called.- Specified by:
- startUpdatein interface- SailConnection
- Overrides:
- startUpdatein class- AbstractSailConnection
- Throws:
- SailException
 
 - 
addStatementpublic void addStatement(UpdateContext op, Resource subj, IRI pred, Value obj, Resource... contexts) throws SailException Description copied from class:AbstractSailConnectionThe default implementation buffers added statements until the update operation is complete.- Specified by:
- addStatementin interface- SailConnection
- Overrides:
- addStatementin class- AbstractSailConnection
- Parameters:
- op- operation properties of the- UpdateExproperation producing these statements.
- subj- The subject of the statement to add.
- pred- The predicate of the statement to add.
- obj- The object of the statement to add.
- contexts- The context(s) to add the statement to. Note that this parameter is a vararg and as such is optional. If no contexts are specified, a context-less statement will be added.
- Throws:
- SailException- If the statement could not be added, for example because no transaction is active.
 
 - 
removeStatementpublic void removeStatement(UpdateContext op, Resource subj, IRI pred, Value obj, Resource... contexts) throws SailException Description copied from class:AbstractSailConnectionThe default implementation buffers removed statements until the update operation is complete.- Specified by:
- removeStatementin interface- SailConnection
- Overrides:
- removeStatementin class- AbstractSailConnection
- Parameters:
- op- operation properties of the- UpdateExproperation removing these statements.
- subj- The subject of the statement that should be removed.
- pred- The predicate of the statement that should be removed.
- obj- The object of the statement that should be removed.
- contexts- The context(s) from which to remove the statement. Note that this parameter is a vararg and as such is optional. If no contexts are specified the method operates on the entire repository. A null value can be used to match context-less statements.
- Throws:
- SailException- If the statement could not be removed, for example because no transaction is active.
 
 - 
endUpdateInternalprotected void endUpdateInternal(UpdateContext op) throws SailException - Overrides:
- endUpdateInternalin class- AbstractSailConnection
- Throws:
- SailException
 
 - 
addInferredStatementpublic boolean addInferredStatement(Resource subj, IRI pred, Value obj, Resource... contexts) throws SailException Description copied from interface:InferencerConnectionAdds an inferred statement to a specific context.- Specified by:
- addInferredStatementin interface- InferencerConnection
- Parameters:
- subj- The subject of the statement to add.
- pred- The predicate of the statement to add.
- obj- The object of the statement to add.
- contexts- The context(s) to add the statement to. Note that this parameter is a vararg and as such is optional. If no contexts are supplied the method operates on the entire repository.
- Throws:
- SailException- If the statement could not be added.
 
 - 
removeInferredStatementpublic boolean removeInferredStatement(Resource subj, IRI pred, Value obj, Resource... contexts) throws SailException Description copied from interface:InferencerConnectionRemoves an inferred statement from a specific context.- Specified by:
- removeInferredStatementin interface- InferencerConnection
- Parameters:
- subj- The subject of the statement that should be removed.
- pred- The predicate of the statement that should be removed.
- obj- The object of the statement that should be removed.
- contexts- The context(s) from which to remove the statements. Note that this parameter is a vararg and as such is optional. If no contexts are supplied the method operates on the entire repository.
- Throws:
- SailException- If the statement could not be removed.
 
 - 
clearInternalprotected void clearInternal(Resource... contexts) throws SailException - Specified by:
- clearInternalin class- AbstractSailConnection
- Throws:
- SailException
 
 - 
clearInferredpublic void clearInferred(Resource... contexts) throws SailException Description copied from interface:InferencerConnectionRemoves all inferred statements from the specified/all contexts. If no contexts are specified the method operates on the entire repository.- Specified by:
- clearInferredin interface- InferencerConnection
- Parameters:
- contexts- The context(s) from which to remove the statements. Note that this parameter is a vararg and as such is optional. If no contexts are supplied the method operates on the entire repository.
- Throws:
- SailException- If the statements could not be removed.
 
 - 
flushUpdatespublic void flushUpdates() throws SailExceptionDescription copied from interface:InferencerConnectionFlushes any pending updates to be processed and the resulting changes to be reported to registeredSailConnectionListeners.- Specified by:
- flushUpdatesin interface- InferencerConnection
- Throws:
- SailException- If the updates could not be processed.
 
 - 
setNamespaceInternalprotected void setNamespaceInternal(String prefix, String name) throws SailException - Specified by:
- setNamespaceInternalin class- AbstractSailConnection
- Throws:
- SailException
 
 - 
removeNamespaceInternalprotected void removeNamespaceInternal(String prefix) throws SailException - Specified by:
- removeNamespaceInternalin class- AbstractSailConnection
- Throws:
- SailException
 
 - 
clearNamespacesInternalprotected void clearNamespacesInternal() throws SailException- Specified by:
- clearNamespacesInternalin class- AbstractSailConnection
- Throws:
- SailException
 
 
- 
 
-