/* * 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 <http://www.gnu.org/licenses/lgpl-2.1.html>. */ package org.hibernate.search.test.engine.optimizations; import java.util.ArrayList; import java.util.Collection; import javax.persistence.CascadeType; import javax.persistence.Column; import javax.persistence.Entity; import javax.persistence.FetchType; import javax.persistence.GeneratedValue; import javax.persistence.GenerationType; import javax.persistence.Id; import javax.persistence.OneToMany; import javax.persistence.Table; import org.hibernate.annotations.Proxy; import org.hibernate.search.annotations.ContainedIn; import org.hibernate.search.annotations.Field; /** * Related to test case of HSEARCH-782; indexed properties are defined * via a programmatic configuration. * * @author Adam Harris * @author Sanne Grinovero (C) 2011 Red Hat Inc. */ @Entity @Proxy(lazy = false) @Table(name = "location_group") //not indexed public class LocationGroup { @Id() @GeneratedValue(strategy = GenerationType.AUTO) private Long groupId; @Field @Column(length = 255) private String name; @ContainedIn @OneToMany(mappedBy = "locationGroup", cascade = { CascadeType.ALL }, fetch = FetchType.LAZY) Collection<Location> locations = new ArrayList<Location>(); public LocationGroup() { } public LocationGroup(String name) { this.name = name; } public Long getGroupId() { return groupId; } public void setGroupId(Long groupId) { this.groupId = groupId; } public String getName() { return name; } public void setName(String name) { this.name = name; } public Collection<Location> getLocations() { return locations; } public void setLocations(Collection<Location> locations) { this.locations = locations; } }