org.hibernate.search.query.dsl.QueryBuilder Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of hibernate-search-engine Show documentation
Show all versions of hibernate-search-engine Show documentation
Core of the Object/Lucene mapper, query engine and index management
/*
* Hibernate Search, full-text search for your domain model
*
* License: GNU Lesser General Public License (LGPL), version 2.1 or later
* See the lgpl.txt file in the root directory or .
*/
package org.hibernate.search.query.dsl;
/**
* Builds up Lucene queries for a given entity type following the fluent API pattern.
*
*
* The resulting {@link org.apache.lucene.search.Query} can
* be obtained from the final {@link Termination} object of the invocation chain.
*
* If required, the resulting {@code Query} instance can be modified or combined with other queries created
* via this fluent API or via the native Lucene API.
*
* @author Emmanuel Bernard
*/
public interface QueryBuilder {
/**
* Build a term query (see {@link org.apache.lucene.search.TermQuery}).
*
* @return a {@code TermContext} instance for building the term query
*/
TermContext keyword();
/**
* Build a range query (see {@link org.apache.lucene.search.TermRangeQuery}.
*
* @return a {@code RangeContext} instance for building the range query
*/
RangeContext range();
/**
* Build a phrase query (see {@link org.apache.lucene.search.PhraseQuery}).
*
* @return a {@code PhraseContext} instance for building the range query
*/
PhraseContext phrase();
/**
* Start for building a boolean query.
*
* @return a {@code BooleanJunction} instance for building the boolean query
*/
BooleanJunction bool();
/**
* Query matching all documents (typically mixed with a boolean query).
*
* @return an {@code AllContext}
*/
AllContext all();
/**
* Build a facet query.
*
* @return the facet context as entry point for building the facet request
*/
FacetContext facet();
/**
* Build a spatial query.
*/
SpatialContext spatial();
/**
* Build a query matching resembling content.
*
* It uses an approach similar to Lucene's {@code MoreLikeThis}
*
* @hsearch.experimental More Like This queries are considered experimental
*/
MoreLikeThisContext moreLikeThis();
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy