org.hibernate.search.query.engine.spi.HSQuery Maven / Gradle / Ivy
/*
* 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.engine.spi;
import java.util.List;
import org.apache.lucene.search.Explanation;
import org.apache.lucene.search.Filter;
import org.apache.lucene.search.Query;
import org.apache.lucene.search.Sort;
import org.hibernate.search.engine.ProjectionConstants;
import org.hibernate.search.engine.integration.impl.ExtendedSearchIntegrator;
import org.hibernate.search.filter.FullTextFilter;
import org.hibernate.search.query.dsl.BooleanJunction;
import org.hibernate.search.query.dsl.MustJunction;
import org.hibernate.search.spatial.Coordinates;
import org.hibernate.search.spi.IndexedTypeSet;
import org.hibernate.search.spi.SearchIntegrator;
/**
* Defines and executes an Hibernate Search query (wrapping a Lucene query).
* Uses fluent APIs to define the query and offer a few alternatives
* on how to execute the query.
*
* This object is not meant to be thread safe.
* The typical usage is as follow
*
* {@code //get query object
* HSQuery query = searchIntegrator.createHSQuery();
* //configure query object
* query
* .luceneQuery( luceneQuery )
* .timeoutExceptionFactory( exceptionFactory )
* .targetedEntities( Arrays.asList( classes ) );
*
* [...]
*
* //start timeout counting
* query.getTimeoutManager().start();
*
* //query execution and use
* List entityInfos = query.getEntityInfos();
* [...]
*
* //done with the core of the query
* query.getTimeoutManager().stop();
* }
*
*
* @author Emmanuel Bernard
*/
public interface HSQuery extends ProjectionConstants {
/**
* Defines the underlying Lucene query
*
* @param query the Lucene query
* @return {@code this} to allow method chaining
*/
HSQuery luceneQuery(Query query);
HSQuery tenantIdentifier(String tenantId);
/**
* Lets Lucene sort the results. This is useful when you have
* different sort requirements than the default Lucene ranking.
* Without Lucene sorting you would have to retrieve the full result set and
* order the Hibernate objects.
*
* @param sort The Lucene sort object.
* @return {@code this} to allow for method chaining
*/
HSQuery sort(Sort sort);
/**
* Allows to use lucene filters.
*
* @param filter The Lucene filter.
* @return {@code this} to allow for method chaining
*
* @deprecated use the {@link org.hibernate.search.annotations.FullTextFilterDef} approach,
* or handle filtering when building the query (see {@link BooleanJunction#must(Query)}
* and {@link MustJunction#disableScoring()}).
*/
@Deprecated
HSQuery filter(Filter filter);
/**
* Define the timeout exception factory to customize the exception returned by the user.
* Defaults to returning {@link org.hibernate.search.query.engine.QueryTimeoutException}
*
* @param exceptionFactory the timeout exception factory to use
* @return {@code this} to allow for method chaining
*/
HSQuery timeoutExceptionFactory(TimeoutExceptionFactory exceptionFactory);
/**
* Defines the Lucene field names projected and returned in a query result
* Each field is converted back to it's object representation, an Object[] being returned for each "row"
* (similar to an HQL or a Criteria API projection).
*
* A projectable field must be stored in the Lucene index and use a {@link org.hibernate.search.bridge.TwoWayFieldBridge}
* Unless notified in their JavaDoc, all built-in bridges are two-way. All @DocumentId fields are projectable by design.
*
* If the projected field is not a projectable field, null is returned in the object[]
*
* @param fields the projected field names
* @return {@code this} to allow for method chaining
*/
HSQuery projection(String... fields);
/**
* Set the first element to retrieve. If not set, elements will be
* retrieved beginning from element 0.
*
* @param firstResult a element number, numbered from 0
* @return {@code this} to allow for method chaining
*/
HSQuery firstResult(int firstResult);
/**
* Set the maximum number of elements to retrieve. If not set,
* there is no limit to the number of elements retrieved.
*
* @param maxResults the maximum number of elements
*
* @return {@code this} in order to allow method chaining
*/
HSQuery maxResults(int maxResults);
/**
* @return the targeted entity types
*/
IndexedTypeSet getTargetedEntities();
/**
* @return a set of indexed entities corresponding to the class hierarchy of the targeted entities
*/
IndexedTypeSet getIndexedTargetedEntities();
/**
* @return the projected field names
*/
String[] getProjectedFields();
/**
* @return {@code true} if the projected field names contain the
* {@link org.hibernate.search.engine.ProjectionConstants#THIS} constant.
*/
boolean hasThisProjection();
/**
* @return the timeout manager. Make sure to wrap your HSQuery usage around a {@code timeoutManager.start()} and {@code timeoutManager.stop()}.
*/
TimeoutManager getTimeoutManager();
/**
* @return return the manager for all faceting related operations
*/
FacetManager getFacetManager();
/**
* @return the underlying Lucene query (if any)
*/
Query getLuceneQuery();
/**
* @return a String representation of the underlying query
*/
String getQueryString();
/**
* Execute the Lucene query and return the list of {@code EntityInfo}s populated with
* metadata and projection. {@link org.hibernate.search.engine.ProjectionConstants#THIS} if projected is not populated.
* It is the responsibility of the object source integration.
*
* @return list of {@code EntityInfo}s populated with metadata and projection
*/
List queryEntityInfos();
/**
* Execute the Lucene query and return a traversable object over the results.
* Results are lazily fetched.
* {@link org.hibernate.search.engine.ProjectionConstants#THIS} if projected is not populated. It is the responsibility
* of the object source integration.
* The returned {@code DocumentExtractor} must be closed by the caller to release Lucene resources.
*
* @return the {@code DocumentExtractor} instance
*/
DocumentExtractor queryDocumentExtractor();
/**
* @return the number of hits for this search
*
* Caution:
* The number of results might be slightly different from
* what the object source returns if the index is
* not in sync with the store at the time of query.
*/
int queryResultSize();
/**
* Return the Lucene {@link org.apache.lucene.search.Explanation}
* object describing the score computation for the matching object/document
* in the current query
*
* @param documentId Lucene Document id to be explain. This is NOT the object id
* @return Lucene Explanation
*/
Explanation explain(int documentId);
/**
* Enable a given filter by its name.
*
* @param name the name of the filter to enable
* @return Returns a {@code FullTextFilter} object that allows filter parameter injection
*/
FullTextFilter enableFullTextFilter(String name);
/**
* Disable a given filter by its name.
*
* @param name the name of the filter to disable.
*/
void disableFullTextFilter(String name);
/**
*
getExtendedSearchIntegrator.
*
* @return the {@code ExtendedSearchIntegrator} instance
* @deprecated should be at most SearchIntegrator, preferably removed altogether
*/
@Deprecated
ExtendedSearchIntegrator getExtendedSearchIntegrator();
/**
* afterDeserialise.
*
* @param integrator a {@link org.hibernate.search.spi.SearchIntegrator} object.
*/
void afterDeserialise(SearchIntegrator integrator);
/**
* setSpatialParameters.
*
* @param center center of the spatial search
* @param fieldName name ot the spatial field
* @return {@code this} to allow for method chaining
*/
HSQuery setSpatialParameters(Coordinates center, String fieldName);
}