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

javax.persistence.NamedEntityGraph Maven / Gradle / Ivy

/*
 * 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.TYPE;
import static java.lang.annotation.RetentionPolicy.RUNTIME;

/**
 * The NamedEntityGraph annotation is used to define a named entity graph.  The entity graph may be retrieved by name
 * using the EntityManagerFactory interface.  The entity graph may be used to specify the path and boundaries for find
 * operations or queries.  The NamedEntityGraph annotation must be applied to the entity class that forms the root of
 * the corresponding graph of entities.
 *
 * @since JPA 2.1
 */
@Target({TYPE})
@Retention(RUNTIME)
public @interface NamedEntityGraph {
	/**
	 * The name element is used to refer to the entity graph. It defaults to the entity name of the root entity to
	 * which the annotation is applied. Entity graph names must be unique within the persistence unit.
	 */
	String name() default "";

	/**
	 * The attributeNodes element lists attributes of the annotated entity class that are to be included in the
	 * entity graph.
	 */
	NamedAttributeNode[] attributeNodes() default {};

	/**
	 * The includeAllAttributes element specifies that all attributes of the annotated entity class are to be
	 * included in the entity graph.  An attributeNode element may still be used in conjunction with this element to
	 * specify a subgraph for the attribute.
	 */
	boolean includeAllAttributes() default false;

	/**
	 * The subgraphs element specifies a list of subgraphs, further specifying attributes that are managed types.
	 * These subgraphs are referenced by name from NamedAttributeNode definitions.
	 */
	NamedSubgraph[] subgraphs() default {};

	/**
	 * The subclassSubgraphs element specifies a list of subgraphs that add additional attributes for subclasses of
	 * the root entity to which the annotation is applied.
	 */
	NamedSubgraph[] subclassSubgraphs() default {};
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy