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

org.hibernate.graph.GraphSemantic Maven / Gradle / Ivy

/*
 * Hibernate, Relational Persistence for Idiomatic Java
 *
 * 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.graph;

/**
 * JPA defines 2 distinct semantics for applying an EntityGraph.  This
 * enumeration captures those 2 semantics.
 *
 * @author Steve Ebersole
 */
public enum GraphSemantic {
	/**
	 * Indicates a "fetch graph" EntityGraph.  Attributes explicitly specified
	 * as AttributeNodes are treated as FetchType.EAGER (via join fetch or
	 * subsequent select).
	 * 

* Note: Currently, attributes that are not specified are treated as * FetchType.LAZY or FetchType.EAGER depending on the attribute's definition * in metadata, rather than forcing FetchType.LAZY. */ FETCH( "javax.persistence.fetchgraph" ), /** * Indicates a "load graph" EntityGraph. Attributes explicitly specified * as AttributeNodes are treated as FetchType.EAGER (via join fetch or * subsequent select). Attributes that are not specified are treated as * FetchType.LAZY or FetchType.EAGER depending on the attribute's definition * in metadata */ LOAD( "javax.persistence.loadgraph" ); private final String jpaHintName; GraphSemantic(String jpaHintName) { this.jpaHintName = jpaHintName; } public String getJpaHintName() { return jpaHintName; } public static GraphSemantic fromJpaHintName(String hintName) { assert hintName != null; if ( FETCH.getJpaHintName().equals( hintName ) ) { return FETCH; } if ( LOAD.getJpaHintName().equalsIgnoreCase( hintName ) ) { return LOAD; } throw new IllegalArgumentException( "Unknown EntityGraph hint name [" + hintName + "]; " + "expecting `" + FETCH.jpaHintName + "` or `" + LOAD.jpaHintName + "`." ); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy