javax.persistence.Embedded Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of javax.persistence Show documentation
Show all versions of javax.persistence Show documentation
The Java Persistence API (JPA) : a standard interface-based Java model abstraction of persistence, developed by the JCP.
/*
* Copyright (c) 2008, 2009, 2011 Oracle, Inc. All rights reserved.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v1.0 and Eclipse Distribution License v. 1.0
* which accompanies this distribution. The Eclipse Public License is available
* at http://www.eclipse.org/legal/epl-v10.html and the Eclipse Distribution License
* is available at http://www.eclipse.org/org/documents/edl-v10.php.
*/
package javax.persistence;
import java.lang.annotation.Retention;
import java.lang.annotation.Target;
import static java.lang.annotation.ElementType.ANNOTATION_TYPE;
import static java.lang.annotation.ElementType.FIELD;
import static java.lang.annotation.ElementType.METHOD;
import static java.lang.annotation.RetentionPolicy.RUNTIME;
/**
* Specifies a persistent field or property of an entity whose
* value is an instance of an embeddable class. The embeddable
* class must be annotated as {@link Embeddable}.
*
* The AttributeOverride
, AttributeOverrides
,
* AssociationOverride
, and AssociationOverrides
* annotations may be used to override mappings declared or defaulted
* by the embeddable class.
*
*
* Example:
*
* @Embedded
* @AttributeOverrides({
* @AttributeOverride(name="startDate", column=@Column("EMP_START")),
* @AttributeOverride(name="endDate", column=@Column("EMP_END"))
* })
* public EmploymentPeriod getEmploymentPeriod() { ... }
*
*
* @see Embeddable
* @see AttributeOverride
* @see AttributeOverrides
* @see AssociationOverride
* @see AssociationOverrides
*
* @since Java Persistence 1.0
*/
@Target({ANNOTATION_TYPE, METHOD, FIELD})
@Retention(RUNTIME)
public @interface Embedded {
/**
* (Optional) The entity class that is the target of the association.
*
* Defaults to the type of the field or property that stores the association.
* @return target entity
*/
Class targetEntity() default void.class;
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy