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

jakarta.persistence.NamedEntityGraph Maven / Gradle / Ivy

There is a newer version: 3.2.0
Show newest version
/*
 * Copyright (c) 2011, 2023 Oracle and/or its affiliates. All rights reserved.
 *
 * This program and the accompanying materials are made available under the
 * terms of the Eclipse Public License v. 2.0 which is available at
 * http://www.eclipse.org/legal/epl-2.0,
 * or the Eclipse Distribution License v. 1.0 which is available at
 * http://www.eclipse.org/org/documents/edl-v10.php.
 *
 * SPDX-License-Identifier: EPL-2.0 OR BSD-3-Clause
 */

// Contributors:
//     Petros Splinakis - 2.2
//     Linda DeMichiel - 2.1

package jakarta.persistence;

import java.lang.annotation.Repeatable;
import java.lang.annotation.Target;
import java.lang.annotation.Retention;
import static java.lang.annotation.ElementType.TYPE;
import static java.lang.annotation.RetentionPolicy.RUNTIME;

/**
 * Defines a named {@linkplain EntityGraph entity graph}. This annotation
 * must be applied to the root entity of the graph, and specifies the
 * limits of the graph of associated attributes and entities fetched when
 * an operation which retrieves an instance or instances of the root entity
 * is executed.
 *
 * 

A reference to a named entity graph may be obtained by calling * {@link EntityManager#getEntityGraph(String)}, and may be passed to * {@link EntityManager#find(EntityGraph, Object, FindOption...)}. * * @since 2.1 */ @Repeatable(NamedEntityGraphs.class) @Target({TYPE}) @Retention(RUNTIME) public @interface NamedEntityGraph { /** * (Optional) The name used to identify the entity graph in calls to * {@link EntityManager#getEntityGraph(String)}. If no name is explicitly * specified, the name defaults to the entity name of the annotated root * entity. Entity graph names must be unique within the persistence unit. */ String name() default ""; /** * (Optional) A list of attributes of the entity that are included in * this graph. */ NamedAttributeNode[] attributeNodes() default {}; /** * (Optional) Includes all of the attributes of the annotated * entity class as attribute nodes in the NamedEntityGraph without * the need to explicitly list them. Included attributes can * still be fully specified by an attribute node referencing a * subgraph. */ boolean includeAllAttributes() default false; /** * (Optional) A list of subgraphs that are included in the * entity graph. These are referenced by name from NamedAttributeNode * definitions. */ NamedSubgraph[] subgraphs() default {}; /** * (Optional) A list of subgraphs that will add additional * attributes for subclasses of the annotated entity class to the * entity graph. Specified attributes from superclasses are * included in subclasses. */ NamedSubgraph[] subclassSubgraphs() default {}; }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy