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

org.hibernate.search.annotations.Spatial 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.annotations;

import org.hibernate.search.spatial.SpatialFieldBridgeByHash;

import java.lang.annotation.Documented;
import java.lang.annotation.ElementType;
import java.lang.annotation.Repeatable;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

/**
 * Defines a spatial property.
 *
 * Spatial coordinates can be indexed as latitude / longitude fields and queried
 * via range queries. This is known as the {@code SpatialMode.RANGE} approach.
 *
 * Otherwise, they can be indexed using a spatial hash index. This is known as the
 * {@code SpatialMode.HASH} approach. The size of the grid can be adjusted with {@code topSpatialHashLevel}
 * and {@code bottomSpatialHashLevel}.
 *
 * For more information on which model to use, read the Hibernate Search reference documentation.
 *
 * If your longitude and latitude information are hosted on free properties,
 * Add {@code @Spatial} on the entity (class-level). The {@link Latitude} and {@link Longitude}
 * annotations must mark the properties.
 *
 * 
 * @Entity
 * @Spatial(name="home")
 * public class User {
 *     @Latitude(of="home")
 *     public Double getHomeLatitude() { ... }
 *     @Longitude(of="home")
 *     public Double getHomeLongitude() { ... }
 * }
 * 
* * Alternatively, you can put the latitude / longitude information in a property of * type {@link org.hibernate.search.spatial.Coordinates}. * *
  * @Entity
  * public class User {
  *     @Spatial
  *     public Coordinates getHome() { ... }
  * }
  * 
* * @hsearch.experimental Spatial support is still considered experimental * @author Nicolas Helleringer */ @Retention(RetentionPolicy.RUNTIME) @Target( { ElementType.METHOD, ElementType.FIELD, ElementType.TYPE }) @Documented @Repeatable(Spatials.class) public @interface Spatial { /** * Prefix used to generate field names for a default {@link org.hibernate.search.annotations.Spatial} annotation */ String COORDINATES_DEFAULT_FIELD = "_hibernate_default_coordinates"; /** * The name of the field prefix where spatial index * information is stored in a Lucene document. * * If {@code @Spatial} is hosted on a property, defaults to the property name. * * @return the field name */ String name() default ""; /** * @return Returns an instance of the {@link Store} enum, indicating whether the value should be stored in the document. * Defaults to {@code Store.NO} */ Store store() default Store.NO; /** * @return Returns a {@link Boost} annotation defining a float index time boost value * * @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 Boost boost() default @Boost(value = 1.0F); /** * @return the mode used for Spatial indexing */ SpatialMode spatialMode() default SpatialMode.RANGE; /** * @return top range spatial hash level for spatial indexing */ int topSpatialHashLevel() default SpatialFieldBridgeByHash.DEFAULT_TOP_SPATIAL_HASH_LEVEL; /** * @return bottom spatial hash level for spatial indexing */ int bottomSpatialHashLevel() default SpatialFieldBridgeByHash.DEFAULT_BOTTOM_SPATIAL_HASH_LEVEL; }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy