Ejercicio de programación: Consultas JPQL avanzadas
Este ejercicio de programación está diseñado para poner a prueba tus conocimientos en Hibernate. Es un ejercicio avanzado que pondrá a prueba tus conocimientos expertos.
Información adicional del ejercicio
Este reto requerirá el uso de cláusulas más complejas de JPQL como JOIN, GROUP BY y HAVING, así como el uso de subconsultas.
Contenido del ejercicio
Se te ha encargado desarrollar consultas avanzadas para un sistema de gestión de pedidos que involucra clientes, pedidos y productos. Existen tres entidades principales en la base de datos: Cliente, Pedido y Producto.
Cliente:
id: Long (Identificador único para cada cliente)nombre: String (Nombre del cliente)email: String (Email del cliente)
Pedido:
id: Long (Identificador único para cada pedido)fecha: LocalDate (Fecha en que se realizó el pedido)cliente: Cliente (El cliente que realizó el pedido, relación muchos a uno)productos: List<Producto> (Los productos incluidos en este pedido, relación muchos a muchos)
Producto:
id: Long (Identificador único para cada producto)nombre: String (Nombre del producto)precio: Double (Precio del producto)pedidos: List<Pedido> (Los pedidos que incluyen este producto, relación muchos a muchos)
Crea un archivo llamado GestionPedidosConsultas.java que realice las siguientes consultas utilizando JPQL y un EntityManager:
- Calcular el total gastado en pedidos por cada cliente, ordenados de mayor a menor gasto. Puedes utilizar la función de agregación
SUMpara sumar los precios de los productos. - Encontrar los productos más populares (más incluidos en pedidos), mostrando el nombre del producto y la cantidad de veces que ha sido pedido, pero solo para aquellos productos que han sido pedidos más de 10 veces. Para contar pedidos, puedes usar
COUNTy contar instancias de un id de un pedido, por ejemploCOUNT(p.id). - Obtener una lista de clientes que no han realizado pedidos después de una fecha específica. Para ello puedes usar una subconsulta con
NOT IN. Dentro de la subconsulta, podrías usarSELECT DISTINCTpara elegir clientes sin duplicados.
Asumir que el EntityManager ya está configurado para llamar a entityManager.createQuery directamente.
Como base, puedes utilizar:
import jakarta.persistence.EntityManager;
import jakarta.persistence.TypedQuery;
import java.time.LocalDate;
import java.util.List;
public class GestionPedidosConsultas {
private EntityManager entityManager;
public GestionPedidosConsultas(EntityManager entityManager) {
this.entityManager = entityManager;
}
// Consulta 1: Calcular el total gastado en pedidos por cada cliente
public List<Object[]> calcularTotalGastadoPorClientes() {
}
// Consulta 2: Encontrar los productos más populares
public List<Object[]> encontrarProductosPopulares() {
}
// Consulta 3: Obtener lista de clientes que no han realizado pedidos después de una fecha específica
public List<Cliente> encontrarClientesSinPedidosDespuesDe(LocalDate fecha) {
}
}
Lección relacionada
Este ejercicio está relacionado con la lección "Consultas JPQL avanzadas" de Hibernate. Te recomendamos revisar la lección antes de comenzar.
Ver lección relacionadaMás ejercicios de Hibernate
Explora más ejercicios de programación en Hibernate para mejorar tus habilidades y obtener tu certificación.
Ver más ejercicios de HibernateExplora el curso completo de Hibernate
Descubre más contenido de Hibernate con lecciones, ejercicios y módulos organizados para tu aprendizaje.
Lecciones de Hibernate
Aprende los conceptos fundamentales con tutoriales detallados
Ejercicios de Hibernate
Practica con más ejercicios de programación
Módulos de Hibernate
Explora todos los módulos del curso organizados por temas
Curso completo de Hibernate
Ver el temario completo con todos los contenidos del curso
Todas las tecnologías
Explora todos los cursos de programación disponibles
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 ejercicios prácticos y contenido educativo de calidad para desarrolladores de todos los niveles.
Solución al ejercicio de programación en Hibernate
¡Desbloquea la solución completa!
Completa el ejercicio de programación en Hibernate para acceder a la solución paso a paso, explicaciones detalladas y mejores prácticas.
Practica con ejercicios de programación en Hibernate
Mejora tus habilidades con cientos de ejercicios de práctica, recibe retroalimentación instantánea y obtén tu certificación cuando estés listo.
Asistente de IA
Aprende de tus errores
Progreso
Mide tu avance
Certificación
Valida tus habilidades
Ejercicios de programación en Hibernate: Práctica y Certificación
Los ejercicios de programación son fundamentales para dominar Hibernate. Este ejercicio está diseñado para poner a prueba tus conocimientos prácticos y ayudarte a consolidar lo aprendido en las lecciones teóricas. La práctica constante con ejercicios de programación es la clave para convertirte en un desarrollador experto.
¿Por qué resolver ejercicios de programación?
Resolver ejercicios de programación en Hibernate te permite:
- Aplicar conocimientos teóricos: Poner en práctica los conceptos aprendidos en las lecciones de Hibernate.
- Identificar áreas de mejora: Descubrir qué conceptos necesitas reforzar en tu aprendizaje de Hibernate.
- Prepararte para certificaciones: Los ejercicios te preparan para obtener certificados profesionales en Hibernate.
- Mejorar tu perfil profesional: Demostrar tus habilidades prácticas en Hibernate.
Metodología de aprendizaje
Nuestros ejercicios de programación están diseñados siguiendo una metodología probada de aprendizaje progresivo. Cada ejercicio en Hibernate está cuidadosamente estructurado para llevar tus habilidades al siguiente nivel. Comenzamos con conceptos fundamentales y avanzamos gradualmente hacia desafíos más complejos que reflejan situaciones reales del desarrollo de software profesional.
Certificación y validación de conocimientos
Al completar ejercicios de programación, no solo mejoras tus habilidades técnicas, sino que también puedes obtener certificados que validan tu expertise en Hibernate. Estos certificados son reconocidos por empresas y pueden ser una gran adición a tu perfil profesional de LinkedIn o tu CV como desarrollador.
Los ejercicios están alineados con los estándares de la industria y cubren desde conceptos básicos hasta técnicas avanzadas de programación en Hibernate. Cada ejercicio incluye casos de prueba y ejemplos prácticos que te ayudarán a comprender mejor cómo aplicar lo aprendido en proyectos reales.