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