Class CachingRepositoryConnection
- java.lang.Object
- 
- org.eclipse.rdf4j.repository.base.AbstractRepositoryConnection
- 
- org.eclipse.rdf4j.repository.base.RepositoryConnectionWrapper
- 
- org.eclipse.rdf4j.spring.resultcache.CachingRepositoryConnection
 
 
 
- 
- All Implemented Interfaces:
- AutoCloseable,- DelegatingRepositoryConnection,- RepositoryConnection,- Clearable
 
 public class CachingRepositoryConnection extends RepositoryConnectionWrapper implements Clearable - Since:
- 4.0.0
- Author:
- Florian Kleedorfer
 
- 
- 
Field Summary- 
Fields inherited from class org.eclipse.rdf4j.repository.base.AbstractRepositoryConnectionlogger
 
- 
 - 
Constructor SummaryConstructors Constructor Description CachingRepositoryConnection(RepositoryConnection delegate, LRUResultCache<ReusableTupleQueryResult> globalTupleQueryResultCache, LRUResultCache<ReusableGraphQueryResult> globalGraphQueryResultCache, ResultCacheProperties properties)
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description voidadd(File file, String baseURI, RDFFormat dataFormat, Resource... contexts)Adds RDF data from the specified file to a specific contexts in the repository.voidadd(InputStream in, String baseURI, RDFFormat dataFormat, Resource... contexts)Adds RDF data from an InputStream to the repository, optionally to one or more named contexts.voidadd(Reader reader, String baseURI, RDFFormat dataFormat, Resource... contexts)Adds RDF data from a Reader to the repository, optionally to one or more named contexts.voidadd(Iterable<? extends Statement> statements, Resource... contexts)Adds the supplied statements to this repository, optionally to one or more named contexts.voidadd(URL url, String baseURI, RDFFormat dataFormat, Resource... contexts)Adds the RDF data that can be found at the specified URL to the repository, optionally to one or more named contexts.<E extends Exception>
 voidadd(Iteration<? extends Statement,E> statementIter, Resource... contexts)Adds the supplied statements to this repository, optionally to one or more named contexts.voidadd(Resource subject, IRI predicate, Value object, Resource... contexts)Adds a statement with the specified subject, predicate and object to this repository, optionally to one or more named contexts.voidadd(Statement st, Resource... contexts)Adds the supplied statement to this repository, optionally to one or more named contexts.voidclear(Resource... contexts)Removes all statements from a specific contexts in the repository.voidclearCachedResults()voidclose()Closes the connection, freeing resources.voidmarkDirty()As we are changing the repository's content, we have to reset all caches (even though itGraphQueryprepareGraphQuery(QueryLanguage ql, String queryString, String baseURI)Prepares queries that produce RDF graphs.TupleQueryprepareTupleQuery(QueryLanguage ql, String queryString, String baseURI)Prepares a query that produces sets of value tuples.UpdateprepareUpdate(QueryLanguage ql, String updateString, String baseURI)Prepares an Update operation.voidremove(Iterable<? extends Statement> statements, Resource... contexts)Removes the supplied statements from the specified contexts in this repository.<E extends Exception>
 voidremove(Iteration<? extends Statement,E> statementIter, Resource... contexts)Removes the supplied statements from a specific context in this repository, ignoring any context information carried by the statements themselves.voidremove(Resource subject, IRI predicate, Value object, Resource... contexts)Removes the statement(s) with the specified subject, predicate and object from the repository, optionally restricted to the specified contexts.voidremove(Statement st, Resource... contexts)Removes the supplied statement from the specified contexts in the repository.voidremoveNamespace(String prefix)Removes a namespace declaration by removing the association between a prefix and a namespace name.voidrenewClearable(ClearableAwareUpdate update)voidrenewLocalResultCache(ResultCachingGraphQuery resultCachingGraphQuery)voidrenewLocalResultCache(ResultCachingTupleQuery resultCachingTupleQuery)- 
Methods inherited from class org.eclipse.rdf4j.repository.base.RepositoryConnectionWrapperaddWithoutCommit, begin, begin, begin, clearNamespaces, commit, exportStatements, exportStatements, getContextIDs, getDelegate, getIsolationLevel, getNamespace, getNamespaces, getStatements, hasStatement, hasStatement, isActive, isAutoCommit, isDelegatingAdd, isDelegatingRead, isDelegatingRemove, isEmpty, isOpen, prepare, prepareBooleanQuery, prepareQuery, removeWithoutCommit, rollback, setAutoCommit, setDelegate, setIsolationLevel, setNamespace, setParserConfig, size
 - 
Methods inherited from class org.eclipse.rdf4j.repository.base.AbstractRepositoryConnectionaddWithoutCommit, conditionalCommit, conditionalRollback, export, getParserConfig, getRepository, getValueFactory, prepareBooleanQuery, prepareGraphQuery, prepareQuery, prepareTupleQuery, prepareUpdate, removeWithoutCommit, startLocalTransaction
 - 
Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 - 
Methods inherited from interface org.eclipse.rdf4j.repository.RepositoryConnectionadd, add, add, add, add, add, add, add, export, getParserConfig, getRepository, getStatements, getValueFactory, prepareBooleanQuery, prepareBooleanQuery, prepareGraphQuery, prepareGraphQuery, prepareQuery, prepareQuery, prepareTupleQuery, prepareTupleQuery, prepareUpdate, prepareUpdate, remove, remove
 
- 
 
- 
- 
- 
Constructor Detail- 
CachingRepositoryConnectionpublic CachingRepositoryConnection(RepositoryConnection delegate, LRUResultCache<ReusableTupleQueryResult> globalTupleQueryResultCache, LRUResultCache<ReusableGraphQueryResult> globalGraphQueryResultCache, ResultCacheProperties properties) 
 
- 
 - 
Method Detail- 
renewLocalResultCachepublic void renewLocalResultCache(ResultCachingTupleQuery resultCachingTupleQuery) 
 - 
renewLocalResultCachepublic void renewLocalResultCache(ResultCachingGraphQuery resultCachingGraphQuery) 
 - 
renewClearablepublic void renewClearable(ClearableAwareUpdate update) 
 - 
prepareTupleQuerypublic TupleQuery prepareTupleQuery(QueryLanguage ql, String queryString, String baseURI) throws MalformedQueryException, RepositoryException Description copied from interface:RepositoryConnectionPrepares a query that produces sets of value tuples.- Specified by:
- prepareTupleQueryin interface- RepositoryConnection
- Overrides:
- prepareTupleQueryin class- RepositoryConnectionWrapper
- Parameters:
- ql- The- query languagein which the query is formulated.
- queryString- The query string.
- baseURI- The base URI to resolve any relative URIs that are in the query against, can be null if the query does not contain any relative URIs.
- Returns:
- a TupleQueryready to be evaluated on thisRepositoryConnection.
- Throws:
- MalformedQueryException- If the supplied query is malformed.
- RepositoryException
 
 - 
prepareGraphQuerypublic GraphQuery prepareGraphQuery(QueryLanguage ql, String queryString, String baseURI) throws MalformedQueryException, RepositoryException Description copied from interface:RepositoryConnectionPrepares queries that produce RDF graphs.- Specified by:
- prepareGraphQueryin interface- RepositoryConnection
- Overrides:
- prepareGraphQueryin class- RepositoryConnectionWrapper
- Parameters:
- ql- The- query languagein which the query is formulated.
- queryString- The query string.
- baseURI- The base URI to resolve any relative URIs that are in the query against, can be null if the query does not contain any relative URIs.
- Returns:
- a GraphQueryready to be evaluated on thisRepositoryConnection.
- Throws:
- MalformedQueryException- If the supplied query is malformed.
- RepositoryException
 
 - 
prepareUpdatepublic Update prepareUpdate(QueryLanguage ql, String updateString, String baseURI) throws MalformedQueryException, RepositoryException Description copied from interface:RepositoryConnectionPrepares an Update operation.- Specified by:
- prepareUpdatein interface- RepositoryConnection
- Overrides:
- prepareUpdatein class- RepositoryConnectionWrapper
- Parameters:
- ql- The- query languagein which the update operation is formulated.
- updateString- The update operation string.
- baseURI- The base URI to resolve any relative URIs that are in the update against, can be null if the update does not contain any relative URIs.
- Returns:
- a Updateready to be executed on thisRepositoryConnection.
- Throws:
- MalformedQueryException- If the supplied update operation string is malformed.
- RepositoryException
 
 - 
closepublic void close() throws RepositoryExceptionDescription copied from interface:RepositoryConnectionCloses the connection, freeing resources. If atransactionisactiveon the connection, all non-committed operations will be lost by actively callingRepositoryConnection.rollback()on any active transactions.Implementation note: All implementations must override this method if they have any resources that they need to free. - Specified by:
- closein interface- AutoCloseable
- Specified by:
- closein interface- RepositoryConnection
- Overrides:
- closein class- RepositoryConnectionWrapper
- Throws:
- RepositoryException- If the connection could not be closed.
 
 - 
markDirtypublic void markDirty() As we are changing the repository's content, we have to reset all caches (even though it
 - 
clearCachedResultspublic void clearCachedResults() - Specified by:
- clearCachedResultsin interface- Clearable
 
 - 
addpublic void add(File file, String baseURI, RDFFormat dataFormat, Resource... contexts) throws IOException, RDFParseException, RepositoryException Description copied from interface:RepositoryConnectionAdds RDF data from the specified file to a specific contexts in the repository.- Specified by:
- addin interface- RepositoryConnection
- Overrides:
- addin class- RepositoryConnectionWrapper
- Parameters:
- file- A file containing RDF data.
- baseURI- The base URI to resolve any relative URIs that are in the data against. This defaults to the value of- file.toURI()if the value is set to null.- Note that if the data contains an embedded base URI, that embedded base URI will overrule the value supplied here (see RFC 3986 section 5.1 for details). 
- dataFormat- The serialization format of the data. If set to null, the format will be automatically determined by examining the file name extension of the supplied File.
- contexts- The contexts to add the data to. Note that this parameter is a vararg and as such is optional. If no contexts are specified, the data is added to any context specified in the actual data file, or if the data contains no context, it is added without context. If one or more contexts are specified the data is added to these contexts, ignoring any context information in the data itself.
- Throws:
- IOException- If an I/O error occurred while reading from the file.
- RDFParseException- If an error was found while parsing the RDF data.
- RepositoryException- If the data could not be added to the repository, for example because the repository is not writable.
 
 - 
addpublic void add(InputStream in, String baseURI, RDFFormat dataFormat, Resource... contexts) throws IOException, RDFParseException, RepositoryException Description copied from interface:RepositoryConnectionAdds RDF data from an InputStream to the repository, optionally to one or more named contexts.- Specified by:
- addin interface- RepositoryConnection
- Overrides:
- addin class- RepositoryConnectionWrapper
- Parameters:
- in- An InputStream from which RDF data can be read.
- baseURI- The base URI to resolve any relative URIs that are in the data against. May be- null.- Note that if the data contains an embedded base URI, that embedded base URI will overrule the value supplied here (see RFC 3986 section 5.1 for details). 
- dataFormat- The serialization format of the data.
- contexts- The contexts to add the data to. If one or more contexts are supplied the method ignores contextual information in the actual data. If no contexts are supplied the contextual information in the input stream is used, if no context information is available the data is added without any context.
- Throws:
- IOException- If an I/O error occurred while reading from the input stream.
- RDFParseException- If an error was found while parsing the RDF data.
- RepositoryException- If the data could not be added to the repository, for example because the repository is not writable.
 
 - 
addpublic void add(Iterable<? extends Statement> statements, Resource... contexts) throws RepositoryException Description copied from interface:RepositoryConnectionAdds the supplied statements to this repository, optionally to one or more named contexts.- Specified by:
- addin interface- RepositoryConnection
- Overrides:
- addin class- RepositoryConnectionWrapper
- Parameters:
- statements- The statements that should be added. In case the iterable is- NamespaceAwareand the target repository supports it, the iterable's namespaces are also added to the repository, without overwriting existing ones.
- contexts- The contexts to add the statements to. Note that this parameter is a vararg and as such is optional. If no contexts are specified, each statement is added to any context specified in the statement, or if the statement contains no context, it is added without context. If one or more contexts are specified each statement is added to these contexts, ignoring any context information in the statement itself. ignored.
- Throws:
- RepositoryException- If the statements could not be added to the repository, for example because the repository is not writable.
 
 - 
addpublic <E extends Exception> void add(Iteration<? extends Statement,E> statementIter, Resource... contexts) throws RepositoryException, E extends Exception Description copied from interface:RepositoryConnectionAdds the supplied statements to this repository, optionally to one or more named contexts.- Specified by:
- addin interface- RepositoryConnection
- Overrides:
- addin class- RepositoryConnectionWrapper
- Parameters:
- statementIter- The statements to add. In case the iteration is a- CloseableIteration, it will be closed before this method returns.
- contexts- The contexts to add the statements to. Note that this parameter is a vararg and as such is optional. If no contexts are specified, each statement is added to any context specified in the statement, or if the statement contains no context, it is added without context. If one or more contexts are specified each statement is added to these contexts, ignoring any context information in the statement itself. ignored.
- Throws:
- RepositoryException- If the statements could not be added to the repository, for example because the repository is not writable.
- E extends Exception
 
 - 
addpublic void add(Reader reader, String baseURI, RDFFormat dataFormat, Resource... contexts) throws IOException, RDFParseException, RepositoryException Description copied from interface:RepositoryConnectionAdds RDF data from a Reader to the repository, optionally to one or more named contexts. Note: using a Reader to upload byte-based data means that you have to be careful not to destroy the data's character encoding by enforcing a default character encoding upon the bytes. If possible, adding such data using an InputStream is to be preferred.- Specified by:
- addin interface- RepositoryConnection
- Overrides:
- addin class- RepositoryConnectionWrapper
- Parameters:
- reader- A Reader from which RDF data can be read.
- baseURI- The base URI to resolve any relative URIs that are in the data against. May be- null.- Note that if the data contains an embedded base URI, that embedded base URI will overrule the value supplied here (see RFC 3986 section 5.1 for details). 
- dataFormat- The serialization format of the data.
- contexts- The contexts to add the data to. If one or more contexts are specified the data is added to these contexts, ignoring any context information in the data itself.
- Throws:
- IOException- If an I/O error occurred while reading from the reader.
- RDFParseException- If an error was found while parsing the RDF data.
- RepositoryException- If the data could not be added to the repository, for example because the repository is not writable.
 
 - 
addpublic void add(Resource subject, IRI predicate, Value object, Resource... contexts) throws RepositoryException Description copied from interface:RepositoryConnectionAdds a statement with the specified subject, predicate and object to this repository, optionally to one or more named contexts.- Specified by:
- addin interface- RepositoryConnection
- Overrides:
- addin class- RepositoryConnectionWrapper
- Parameters:
- subject- The statement's subject.
- predicate- The statement's predicate.
- object- The statement's object.
- contexts- The contexts to add the data to. Note that this parameter is a vararg and as such is optional. If no contexts are specified, the data is added to any context specified in the actual data file, or if the data contains no context, it is added without context. If one or more contexts are specified the data is added to these contexts, ignoring any context information in the data itself.
- Throws:
- RepositoryException- If the data could not be added to the repository, for example because the repository is not writable.
 
 - 
addpublic void add(Statement st, Resource... contexts) throws RepositoryException Description copied from interface:RepositoryConnectionAdds the supplied statement to this repository, optionally to one or more named contexts.- Specified by:
- addin interface- RepositoryConnection
- Overrides:
- addin class- RepositoryConnectionWrapper
- Parameters:
- st- The statement to add.
- contexts- The contexts to add the statements to. Note that this parameter is a vararg and as such is optional. If no contexts are specified, the statement is added to any context specified in each statement, or if the statement contains no context, it is added without context. If one or more contexts are specified the statement is added to these contexts, ignoring any context information in the statement itself.
- Throws:
- RepositoryException- If the statement could not be added to the repository, for example because the repository is not writable.
 
 - 
addpublic void add(URL url, String baseURI, RDFFormat dataFormat, Resource... contexts) throws IOException, RDFParseException, RepositoryException Description copied from interface:RepositoryConnectionAdds the RDF data that can be found at the specified URL to the repository, optionally to one or more named contexts.- Specified by:
- addin interface- RepositoryConnection
- Overrides:
- addin class- RepositoryConnectionWrapper
- Parameters:
- url- The URL of the RDF data.
- baseURI- The base URI to resolve any relative URIs that are in the data against. This defaults to the value of- url.toExternalForm()if the value is set to null.- Note that if the data contains an embedded base URI, that embedded base URI will overrule the value supplied here (see RFC 3986 section 5.1 for details). 
- dataFormat- The serialization format of the data. If set to null, the format will be automatically determined by examining the content type in the HTTP response header, and failing that, the file name extension of the supplied URL.
- contexts- The contexts to add the data to. If one or more contexts are specified the data is added to these contexts, ignoring any context information in the data itself.
- Throws:
- IOException- If an I/O error occurred while reading from the URL.
- RDFParseException- If an error was found while parsing the RDF data.
- RepositoryException- If the data could not be added to the repository, for example because the repository is not writable.
 
 - 
clearpublic void clear(Resource... contexts) throws RepositoryException Description copied from interface:RepositoryConnectionRemoves all statements from a specific contexts in the repository.- Specified by:
- clearin interface- RepositoryConnection
- Overrides:
- clearin class- RepositoryConnectionWrapper
- Parameters:
- contexts- The context(s) to remove the data from. 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:
- RepositoryException- If the statements could not be removed from the repository, for example because the repository is not writable.
 
 - 
removepublic void remove(Iterable<? extends Statement> statements, Resource... contexts) throws RepositoryException Description copied from interface:RepositoryConnectionRemoves the supplied statements from the specified contexts in this repository.- Specified by:
- removein interface- RepositoryConnection
- Overrides:
- removein class- RepositoryConnectionWrapper
- Parameters:
- statements- The statements that should be added.
- contexts- The context(s) to remove the data from. Note that this parameter is a vararg and as such is optional. If no contexts are supplied the method operates on the contexts associated with the statement itself, and if no context is associated with the statement, on the entire repository.
- Throws:
- RepositoryException- If the statements could not be added to the repository, for example because the repository is not writable.
 
 - 
removepublic <E extends Exception> void remove(Iteration<? extends Statement,E> statementIter, Resource... contexts) throws RepositoryException, E extends Exception Description copied from interface:RepositoryConnectionRemoves the supplied statements from a specific context in this repository, ignoring any context information carried by the statements themselves.- Specified by:
- removein interface- RepositoryConnection
- Overrides:
- removein class- RepositoryConnectionWrapper
- Parameters:
- statementIter- The statements to remove. In case the iteration is a- CloseableIteration, it will be closed before this method returns.
- contexts- The context(s) to remove the data from. Note that this parameter is a vararg and as such is optional. If no contexts are supplied the method operates on the contexts associated with the statement itself, and if no context is associated with the statement, on the entire repository.
- Throws:
- RepositoryException- If the statements could not be removed from the repository, for example because the repository is not writable.
- E extends Exception
 
 - 
removepublic void remove(Resource subject, IRI predicate, Value object, Resource... contexts) throws RepositoryException Description copied from interface:RepositoryConnectionRemoves the statement(s) with the specified subject, predicate and object from the repository, optionally restricted to the specified contexts.- Specified by:
- removein interface- RepositoryConnection
- Overrides:
- removein class- RepositoryConnectionWrapper
- Parameters:
- subject- The statement's subject, or null for a wildcard.
- predicate- The statement's predicate, or null for a wildcard.
- object- The statement's object, or null for a wildcard.
- contexts- The context(s) to remove the data from. 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:
- RepositoryException- If the statement(s) could not be removed from the repository, for example because the repository is not writable.
 
 - 
removepublic void remove(Statement st, Resource... contexts) throws RepositoryException Description copied from interface:RepositoryConnectionRemoves the supplied statement from the specified contexts in the repository.- Specified by:
- removein interface- RepositoryConnection
- Overrides:
- removein class- RepositoryConnectionWrapper
- Parameters:
- st- The statement to remove.
- contexts- The context(s) to remove the data from. Note that this parameter is a vararg and as such is optional. If no contexts are supplied the method operates on the contexts associated with the statement itself, and if no context is associated with the statement, on the entire repository.
- Throws:
- RepositoryException- If the statement could not be removed from the repository, for example because the repository is not writable.
 
 - 
removeNamespacepublic void removeNamespace(String prefix) throws RepositoryException Description copied from interface:RepositoryConnectionRemoves a namespace declaration by removing the association between a prefix and a namespace name.- Specified by:
- removeNamespacein interface- RepositoryConnection
- Overrides:
- removeNamespacein class- RepositoryConnectionWrapper
- Parameters:
- prefix- The namespace prefix, or an empty string in case of the default namespace.
- Throws:
- RepositoryException- If the namespace prefix could not be removed.
 
 
- 
 
-