Package org.eclipse.rdf4j.sail.lucene
Interface SearchIndex
- 
- All Known Implementing Classes:
- AbstractLuceneIndex,- AbstractSearchIndex,- ElasticsearchIndex,- LuceneIndex,- LuceneIndexNIOFS,- SolrIndex
 
 public interface SearchIndexA SearchIndex is a one-stop-shop abstraction of a Lucene index. It takes care of proper synchronization of IndexReaders, IndexWriters and IndexSearchers in a way that is suitable for a LuceneSail.- See Also:
- LuceneSail
 
- 
- 
Method SummaryAll Methods Instance Methods Abstract Methods Modifier and Type Method Description booleanaccept(Literal literal)Returns whether the provided literal is accepted by the LuceneIndex to be indexed.voidaddDocuments(Resource subject, List<Statement> statements)Add a complete Lucene Document based on these statements.Do not search for an existing document with the same subject id.voidaddRemoveStatements(Collection<Statement> added, Collection<Statement> removed)Add many statements at the same time, remove many statements at the same time.Ordering by resource has to be done inside this method.voidaddStatement(Statement statement)Indexes the specified Statement.This should be called from within a begin-commit-rollback block.voidbegin()Begins a transaction.voidclear()Clears the indexes.voidclearContexts(Resource... contexts)This should be called from within a begin-commit-rollback block.voidcommit()Commits any changes done to the LuceneIndex since the last commit.The semantics is synchronous to SailConnection.commit(), i.e.Collection<BindingSet>evaluate(SearchQueryEvaluator query)Map<IRI,Set<IRI>>getIndexedTypeMapping()voidinitialize(Properties parameters)booleanisGeoField(String propertyName)Returns true if the given property contains a geometry.booleanisIndexedTypeStatement(Statement statement)Returns true if the given statement is a type statement of the right type, seeLuceneSail.INDEXEDTYPESto use.booleanisTypeFilteringEnabled()is theLuceneSail.INDEXEDTYPESparameter set for this index.booleanisTypeStatement(Statement statement)Returns true if the given statement is a type statement, seeLuceneSail.INDEXEDTYPESto use.voidremoveStatement(Statement statement)Removes the specified Statement from the indexes.This should be called from within a begin-commit-rollbackvoidrollback()voidshutDown()
 
- 
- 
- 
Method Detail- 
initializevoid initialize(Properties parameters) throws Exception - Throws:
- Exception
 
 - 
evaluateCollection<BindingSet> evaluate(SearchQueryEvaluator query) throws SailException - Throws:
- SailException
 
 - 
shutDownvoid shutDown() throws IOException- Throws:
- IOException
 
 - 
acceptboolean accept(Literal literal) Returns whether the provided literal is accepted by the LuceneIndex to be indexed. It for instance does not make much since to index xsd:float.- Parameters:
- literal- the literal to be accepted
- Returns:
- true if the given literal will be indexed by this LuceneIndex
 
 - 
isGeoFieldboolean isGeoField(String propertyName) Returns true if the given property contains a geometry.- Parameters:
- propertyName-
- Returns:
- boolean
 
 - 
isTypeStatementboolean isTypeStatement(Statement statement) Returns true if the given statement is a type statement, seeLuceneSail.INDEXEDTYPESto use. This method should return false ifisTypeFilteringEnabled()returns false.- Parameters:
- statement- statement
- Returns:
- boolean
 
 - 
isTypeFilteringEnabledboolean isTypeFilteringEnabled() is theLuceneSail.INDEXEDTYPESparameter set for this index.- Returns:
- boolean
 
 - 
isIndexedTypeStatementboolean isIndexedTypeStatement(Statement statement) Returns true if the given statement is a type statement of the right type, seeLuceneSail.INDEXEDTYPESto use. This method should return false ifisTypeFilteringEnabled()returns false.- Parameters:
- statement- statement
- Returns:
- boolean
 
 - 
getIndexedTypeMappingMap<IRI,Set<IRI>> getIndexedTypeMapping() - Returns:
- the accepted types for a particular predicate map (predicate -> [objects])
 
 - 
beginvoid begin() throws IOExceptionBegins a transaction.- Throws:
- IOException
 
 - 
commitvoid commit() throws IOExceptionCommits any changes done to the LuceneIndex since the last commit.The semantics is synchronous to SailConnection.commit(), i.e. the LuceneIndex should be committed/rolled back whenever the LuceneSailConnection is committed/rolled back.- Throws:
- IOException
 
 - 
rollbackvoid rollback() throws IOException- Throws:
- IOException
 
 - 
addStatementvoid addStatement(Statement statement) throws IOException Indexes the specified Statement.This should be called from within a begin-commit-rollback block.- Parameters:
- statement-
- Throws:
- IOException
 
 - 
removeStatementvoid removeStatement(Statement statement) throws IOException Removes the specified Statement from the indexes.This should be called from within a begin-commit-rollbackblock. - Parameters:
- statement-
- Throws:
- IOException
 
 - 
addRemoveStatementsvoid addRemoveStatements(Collection<Statement> added, Collection<Statement> removed) throws IOException Add many statements at the same time, remove many statements at the same time.Ordering by resource has to be done inside this method. The passed added/removed sets are disjunct, no statement can be in both. This should be called from within a begin-commit-rollback block.- Parameters:
- added- all added statements, can have multiple subjects
- removed- all removed statements, can have multiple subjects
- Throws:
- IOException
 
 - 
clearContextsvoid clearContexts(Resource... contexts) throws IOException This should be called from within a begin-commit-rollback block.- Parameters:
- contexts-
- Throws:
- IOException
 
 - 
addDocumentsvoid addDocuments(Resource subject, List<Statement> statements) throws IOException Add a complete Lucene Document based on these statements.Do not search for an existing document with the same subject id. (assume the existing document was deleted). This should be called from within a begin-commit-rollback block.- Parameters:
- subject-
- statements- the statements that make up the resource
- Throws:
- IOException
 
 - 
clearvoid clear() throws IOExceptionClears the indexes.- Throws:
- IOException
 
 
- 
 
-