Módulo: API EntityGraph
Este módulo forma parte del curso de Hibernate. .
En Hibernate, la API EntityGraph proporciona una forma avanzada de definir cómo se deben cargar las entidades y sus relaciones en una consulta. Esta funcionalidad es especialmente útil para optimizar el rendimiento de las aplicaciones, evitando la carga innecesaria de datos.
Creación de un EntityGraph
Para crear un EntityGraph en Hibernate, primero se debe definir qué entidades y relaciones se desean cargar. Esto se puede hacer mediante anotaciones en las entidades o programáticamente.
Anotaciones en las entidades
@Entity
@NamedEntityGraph(
name = "usuarioConRoles",
attributeNodes = {
@NamedAttributeNode("roles")
}
)
public class Usuario {
@Id
private Long id;
private String nombre;
@OneToMany(fetch = FetchType.LAZY)
private Set<Rol> roles;
}
En este ejemplo, se define un EntityGraph
llamado usuarioConRoles
para la entidad Usuario
, que incluye la relación con la entidad Rol
.
Definición programática
EntityGraph<Usuario> entityGraph = entityManager.createEntityGraph(Usuario.class);
entityGraph.addAttributeNodes("roles");
Aquí se define el EntityGraph
programáticamente, añadiendo los atributos que se desean cargar.
Uso de EntityGraph en consultas
Una vez definido el EntityGraph
, se puede utilizar en consultas para controlar la carga de entidades.
Consultas con JPQL
TypedQuery<Usuario> query = entityManager.createQuery(
"SELECT u FROM Usuario u WHERE u.nombre = :nombre", Usuario.class);
query.setParameter("nombre", "Juan");
query.setHint("jakarta.persistence.fetchgraph", entityGraph);
List<Usuario> usuarios = query.getResultList();
En este caso, la consulta utiliza el EntityGraph
para cargar únicamente los atributos especificados.
Consultas con Criteria API
CriteriaBuilder cb = entityManager.getCriteriaBuilder();
CriteriaQuery<Usuario> cq = cb.createQuery(Usuario.class);
Root<Usuario> usuario = cq.from(Usuario.class);
cq.select(usuario).where(cb.equal(usuario.get("nombre"), "Juan"));
TypedQuery<Usuario> query = entityManager.createQuery(cq);
query.setHint("jakarta.persistence.fetchgraph", entityGraph);
List<Usuario> usuarios = query.getResultList();
Aquí se muestra cómo aplicar el EntityGraph
en una consulta utilizando Criteria API.
Beneficios de usar EntityGraph
El uso de EntityGraph
en Hibernate ofrece varios beneficios:
- Optimización de rendimiento: Permite cargar solo las entidades y relaciones necesarias, reduciendo el uso de memoria y el tiempo de ejecución de las consultas.
- Flexibilidad: Facilita la creación de diferentes grafos de entidades según las necesidades específicas de cada consulta.
- Mantenimiento del código: Ayuda a mantener el código más limpio y modular, separando la lógica de carga de entidades de la lógica de negocio.
Otros módulos de este curso
API EntityGraph
Todos los módulos del curso
Navega entre los módulos de Hibernate
API EntityGraph
Estás aquíExplora más sobre Hibernate
Descubre más recursos de Hibernate

Alan Sastre
Ingeniero de Software y formador, CEO en CertiDevs
Ingeniero de software especializado en Full Stack y en Inteligencia Artificial. Como CEO de CertiDevs, Hibernate es una de sus áreas de expertise. Con más de 15 años programando, 6K seguidores en LinkedIn y experiencia como formador, Alan se dedica a crear contenido educativo de calidad para desarrolladores de todos los niveles.