All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.hibernate.search.bridge.LuceneOptions Maven / Gradle / Ivy

There is a newer version: 5.11.12.Final
Show newest version
/*
 * 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.bridge;

import org.apache.lucene.document.Document;
import org.apache.lucene.document.Field;

/**
 * A helper class for building Field objects and associating them to Documents.
 * A wrapper class for Lucene parameters needed for indexing.
 *
 * The recommended approach to index is to use {@link #addFieldToDocument(String, String, org.apache.lucene.document.Document)}
 * or {@link #addNumericFieldToDocument(String, Object, org.apache.lucene.document.Document)} as all the options declared by
 * the user are transparently carried over. Compression is also provided transparently.
 * 
 * {@code String fieldValue = convertToString(value);
 * luceneOptions.addFieldToDocument(name, fieldValue, document);
 * // Numeric
 * Double aDouble = ...
 * luceneOptions.addNumericFieldToDocument(name, value, document);
 * }
 * 
* * @author Emmanuel Bernard * @author Sanne Grinovero * @author Hardy Ferentschik */ public interface LuceneOptions { /** * Add a new field with the name {@code fieldName} to the Lucene Document {@code document} using the value * {@code indexedString}. * If the indexedString is null then the field is not added to the document. * * The field options are following the user declaration: *
    *
  • stored or not
  • *
  • compressed or not
  • *
  • what type of indexing strategy
  • *
  • what type of term vector strategy
  • *
* * @param fieldName The field name * @param indexedString The value to index * @param document the document to which to add the new field */ void addFieldToDocument(String fieldName, String indexedString, Document document); /** * Add a new NumericField with the name {@code fieldName} to the Lucene Document {@code document} * using the value {@code numericValue}. If the value is not numeric then the field is not added to the document * * @param fieldName The name of the field * @param numericValue The numeric value, either an Int, Long, Float or Double * @param document the document to which to add the new field */ void addNumericFieldToDocument(String fieldName, Object numericValue, Document document); /** * Add a new sorted doc values field with the name {@code fieldName} to the Lucene Document * {@code document} using the value {@code indexedString}. *

* If the indexedString is null then the field is not added to the document. * * @param fieldName The field name * @param indexedString The value to index * @param document the document to which to add the new field */ void addSortedDocValuesFieldToDocument(String fieldName, String indexedString, Document document); /** * Add a new numeric doc values field with the name {@code fieldName} to the Lucene Document * {@code document} using the value {@code numericValue}. *

* If the value is not numeric then the field is not added to the document * * @param fieldName The name of the field * @param numericValue The numeric value, either an Int, Long, Float or Double * @param document the document to which to add the new field */ void addNumericDocValuesFieldToDocument(String fieldName, Number numericValue, Document document); /** * Prefer the use of {@link #addFieldToDocument(String, String, org.apache.lucene.document.Document)} * over manually building your Field objects and adding them to the Document. * * To use compression either use #addFieldToDocument or refer * to Lucene documentation to implement your own compression * strategy. * * @return the compression strategy declared by the user {@code true} if the field value is compressed, {@code false} otherwise. */ boolean isCompressed(); /** * Prefer the use of {@link #addFieldToDocument(String, String, org.apache.lucene.document.Document)} * over manually building your Field objects and adding them to the Document. * * {@code org.apache.lucene.document.Field.Store.YES} if the field is stored * {@code org.apache.lucene.document.Field.Store.NO} otherwise. * * To determine if the field must be compressed, use {@link #isCompressed()}. * * Starting from version 3.3, Store.COMPRESS is no longer returned, use {@link #isCompressed()} * * To use compression either use #addFieldToDocument or refer * to Lucene documentation to implement your own compression * strategy. * * @return Returns the store strategy declared by the user */ Field.Store getStore(); /** * Prefer the use of {@link #addFieldToDocument(String, String, org.apache.lucene.document.Document)} * over manually building your Field objects and adding them to the Document. * * @return Returns the indexing strategy declared by the user */ Field.Index getIndex(); /** * Prefer the use of {@link #addFieldToDocument(String, String, org.apache.lucene.document.Document)} * over manually building your Field objects and adding them to the Document. * * @return Returns the term vector strategy declared by the user */ Field.TermVector getTermVector(); /** * Prefer the use of {@link #addFieldToDocument(String, String, org.apache.lucene.document.Document)} * over manually building your Field objects and adding them to the Document. * * @return Returns the boost factor declared by the user * * @deprecated Index-time boosting will not be possible anymore starting from Lucene 7. * You should use query-time boosting instead, for instance by calling * {@link org.hibernate.search.query.dsl.FieldCustomization#boostedTo(float) boostedTo(float)} * when building queries with the Hibernate Search query DSL. */ @Deprecated float getBoost(); /** * @return Returns the string for indexing {@code null} values. {@code null} is returned in case no null token has * been specified. */ String indexNullAs(); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy