Package org.eclipse.rdf4j.sail
Interface Sail
- All Known Subinterfaces:
- NotifyingSail,- StackableSail
- All Known Implementing Classes:
- AbstractForwardChainingInferencer,- AbstractNotifyingSail,- AbstractSail,- CustomGraphQueryInferencer,- DedupingInferencer,- DirectTypeHierarchyInferencer,- ElasticsearchStore,- ExtensibleStore,- FedX,- FedXConnection.SailBaseDefaultImpl,- ForwardChainingRDFSInferencer,- LimitedSizeNativeStore,- LmdbStore,- LuceneSail,- MemoryStore,- NativeStore,- NotifyingSailWrapper,- SailWrapper,- SchemaCachingRDFSInferencer,- ShaclSail
public interface Sail
Sail (Storage And Inference Layer) is an interface for RDF storage. RDF Sails can store RDF statements and evaluate
 queries over them. Statements can be stored in named contexts or in the null context. Contexts can be used to group
 sets of statements that logically belong together, for example because they come from the same source. Both URIs and
 blank nodes can be used as context identifiers.
- Author:
- Arjohn Kampman
- 
Method SummaryModifier and TypeMethodDescriptiondefault Supplier<CollectionFactory>Gets a CollectionFactory that may be optimized for this store and may or may not use disk or other resources.Opens a connection on the Sail which can be used to query and update data.Gets the Sail's data directory.Retrieves the defaultIsolationLevellevel on which transactions in this Sail operate.Retrieve theIsolationLevels supported by this SAIL, ordered by increasing complexity.Gets a ValueFactory object that can be used to create IRI-, blank node-, literal- and statement objects.voidinit()Initializes the Sail.booleanChecks whether this Sail object is writable, i.e.voidsetDataDir(File dataDir) Sets the data directory for the Sail.voidshutDown()Shuts down the Sail, giving it the opportunity to synchronize any stale data.
- 
Method Details- 
setDataDirSets the data directory for the Sail. The Sail can use this directory for storage of data, parameters, etc. This directory must be set before the Sail isinitialized.- Throws:
- IllegalStateException- If this method is called when the Sail has already been initialized.
 
- 
getDataDirFile getDataDir()Gets the Sail's data directory.- See Also:
 
- 
initInitializes the Sail. Care should be taken that required initialization parameters have been set before this method is called. Please consult the specific Sail implementation for information about the relevant parameters.- Throws:
- SailException- If the Sail could not be initialized.
- Since:
- 2.5
 
- 
shutDownShuts down the Sail, giving it the opportunity to synchronize any stale data. Care should be taken that all initialized Sails are being shut down before an application exits to avoid potential loss of data. Once shut down, a Sail can no longer be used until it is re-initialized.- Throws:
- SailException- If the Sail object encountered an error or unexpected situation internally.
 
- 
isWritableChecks whether this Sail object is writable, i.e. if the data contained in this Sail object can be changed.- Throws:
- SailException
 
- 
getConnectionOpens a connection on the Sail which can be used to query and update data. Depending on how the implementation handles concurrent access, a call to this method might block when there is another open connection on this Sail.- Throws:
- SailException- If no transaction could be started, for example because the Sail is not writable.
- IllegalStateException- If the Sail has not been initialized or has been shut down.
 
- 
getValueFactoryValueFactory getValueFactory()Gets a ValueFactory object that can be used to create IRI-, blank node-, literal- and statement objects.- Returns:
- a ValueFactory object for this Sail object.
 
- 
getSupportedIsolationLevelsList<IsolationLevel> getSupportedIsolationLevels()Retrieve theIsolationLevels supported by this SAIL, ordered by increasing complexity.- Returns:
- a non-empty List of supported Isolation Levels, in order of increasing complexity. Every SAIL supports at
         least one IsolationLevel.
 
- 
getDefaultIsolationLevelIsolationLevel getDefaultIsolationLevel()Retrieves the defaultIsolationLevellevel on which transactions in this Sail operate.- Returns:
- the IsolationLevelthat will be used withSailConnection.begin(), for SAIL connections returned bygetConnection().
 
- 
getCollectionFactoryGets a CollectionFactory that may be optimized for this store and may or may not use disk or other resources.- Returns:
- a CollectionFactory
 
 
-