SpringBoot
Tutorial SpringBoot: Consultas JPQL con @Query en Spring Data JPA
Spring Boot query: consultas y ejemplos. Domina la realización de consultas en Spring Boot utilizando query con ejemplos prácticos.
Aprende SpringBoot GRATIS y certifícateJPQL o Jakarta Persistence Query Language es una plataforma independiente de lenguaje de consulta orientada a objetos.
Se usa para hacer consultas contra entidades almacenadas en una base de datos relacional. Spring Data JPA utiliza JPQL para implementar consultas personalizadas y avanzadas. JPQL es similar en muchos aspectos a SQL, y se pueden hacer las mismas operaciones básicas, como SELECT, UPDATE, DELETE, JOIN, GROUP BY, ORDER BY, etc.
La principal diferencia es que JPQL permite una sintaxis orientada a objetos, lo que facilita la creación de consultas.
Cómo utilizar @Query con JPQL
En Spring Data JPA, se puede usar la anotación @Query
para escribir consultas JPQL personalizadas.
El uso de la anotación @Query
es bastante simple y directo. Simplemente, se escribe la consulta JPQL como un valor de la anotación @Query
.
Por ejemplo, supóngase que se tiene una entidad Usuario
:
@Entity
public class Usuario {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
private String nombre;
private String email;
private String ciudad;
// getters y setters
}
Ahora, se crea un repositorio para la entidad Usuario
. En este repositorio, se pueden definir las consultas JPQL personalizadas utilizando la anotación @Query
.
public interface UsuarioRepositorio extends JpaRepository<Usuario, Long> {
@Query("SELECT u FROM Usuario u WHERE u.ciudad = ?1")
List<Usuario> findUsuariosByCiudad(String ciudad);
}
En este caso, se ha definido un método findUsuariosByCiudad
que acepta un parámetro ciudad
y devuelve una lista de usuarios que viven en esa ciudad. La consulta JPQL para este método se define en la anotación @Query
.
Parámetros de Consulta
En el ejemplo anterior, se ha utilizado un parámetro posicional (?1
) para representar el valor de entrada de la consulta. Este es el método más básico para pasar parámetros a una consulta JPQL.
Sin embargo, también pueden utilizarse parámetros con nombre para hacer que las consultas sean más legibles. Aquí hay un ejemplo de cómo se puede hacer esto:
public interface UsuarioRepositorio extends JpaRepository<Usuario, Long> {
@Query("SELECT u FROM Usuario u WHERE u.ciudad = :ciudad")
List<Usuario> findUsuariosByCiudad(@Param("ciudad") String ciudad);
}
En este caso, se ha reemplazado el parámetro posicional por uno con nombre (:ciudad
) y hemos anotado el parámetro del método con @Param("ciudad")
. Esto hace que nuestra consulta sea más legible, ya que ahora está claro que el parámetro del método ciudad
se corresponde con el parámetro de la consulta ciudad
.
Modificación de Consultas con @Modifying
Spring Data JPA también permite ejecutar consultas de actualización y borrado con la anotación @Query
. Para hacer esto, es necesario marcar el método con la anotación @Modifying
.
Aquí hay un ejemplo de cómo se puede hacer esto:
public interface UsuarioRepositorio extends JpaRepository<Usuario, Long> {
@Modifying
@Query("UPDATE Usuario u SET u.ciudad = :ciudad WHERE u.id = :id")
int actualizarCiudadUsuario(@Param("id") Long id, @Param("ciudad") String ciudad);
}
En este caso, se ha definido un método actualizarCiudadUsuario
que acepta dos parámetros id
y ciudad
y actualiza la ciudad de un usuario. La consulta JPQL para este método se define en la anotación @Query
, y también se ha marcado este método con la anotación @Modifying
para indicar que esta consulta modifica el estado de la base de datos.
Joins en JPQL
Al igual que SQL, JPQL ofrece soporte para operaciones de JOIN para combinar registros de dos o más tablas en una base de datos. Aquí hay un ejemplo de cómo se puede hacer esto:
public interface PedidoRepositorio extends JpaRepository<Pedido, Long> {
@Query("SELECT p FROM Pedido p JOIN p.usuario u WHERE u.nombre = :nombre")
List<Pedido> findPedidosPorNombreUsuario(@Param("nombre") String nombre);
}
En este ejemplo, Pedido
es una entidad que tiene una asociación con la entidad Usuario
. La consulta JPQL selecciona todos los pedidos que pertenecen a un usuario con un nombre específico.
Funciones de agregado
JPQL también admite funciones de agregado, que realizan una operación en un conjunto de valores para devolver un solo valor. Las funciones de agregado de JPQL incluyen COUNT()
, AVG()
, SUM()
, MIN()
, MAX()
, y se pueden usar en la cláusula SELECT
o HAVING
de una consulta JPQL.
Aquí hay un ejemplo de cómo se puede usar la función COUNT()
:
public interface UsuarioRepositorio extends JpaRepository<Usuario, Long> {
@Query("SELECT COUNT(u) FROM Usuario u WHERE u.ciudad = :ciudad")
Long contarUsuariosPorCiudad(@Param("ciudad") String ciudad);
}
En este ejemplo, la consulta JPQL cuenta el número de usuarios que viven en una ciudad específica.
Subconsultas
JPQL también admite subconsultas, que son consultas que se incrustan en otras consultas. Se pueden usar en la cláusula WHERE
o HAVING
de una consulta JPQL.
Aquí hay un ejemplo de cómo se puede usar una subconsulta:
public interface UsuarioRepositorio extends JpaRepository<Usuario, Long> {
@Query("SELECT u FROM Usuario u WHERE u.id IN (SELECT p.usuario.id FROM Pedido p WHERE p.total > :total)")
List<Usuario> findUsuariosConPedidoMayorA(@Param("total") BigDecimal total);
}
En este ejemplo, la consulta JPQL selecciona los usuarios que han realizado un pedido con un total mayor a un valor específico.
Consultas nativas
Spring Data JPA permite la ejecución de consultas nativas mediante el uso de la anotación @Query
con el atributo nativeQuery = true
.
Esto puede ser útil en situaciones donde JPQL no pueda satisfacer las necesidades de consulta o cuando se quiera hacer uso de características específicas de la base de datos subyacente que no están disponibles en JPQL.
Aquí hay un ejemplo breve de cómo se puede usar una consulta nativa:
public interface UsuarioRepositorio extends JpaRepository<Usuario, Long> {
@Query(value = "SELECT * FROM usuarios WHERE ciudad = :ciudad", nativeQuery = true)
List<Usuario> findUsuariosByCiudad(@Param("ciudad") String ciudad);
}
En este ejemplo, se ejecuta una consulta SQL nativa que selecciona todos los usuarios de una ciudad específica.
Es importante tener en cuenta que el uso de consultas nativas puede hacer que la aplicación sea menos portable, ya que se están escribiendo consultas que son específicas para una base de datos y no funcionarán necesariamente en otro tipo de bases de datos.
Además, debe tenerse cuidado con la inyección de SQL al usar consultas nativas, asegurándose de que los valores de los parámetros de las consultas no sean manipulados por los usuarios para prevenir la inyección de SQL.
Ejercicios de esta lección Consultas JPQL con @Query en Spring Data JPA
Evalúa tus conocimientos de esta lección Consultas JPQL con @Query en Spring Data JPA con nuestros retos de programación de tipo Test, Puzzle, Código y Proyecto con VSCode, guiados por IA.
API Query By Example (QBE)
Identificadores y relaciones JPA
Borrar datos de base de datos
Web y Test Starters
Métodos find en repositorios
Controladores Spring MVC
Inserción de datos
CRUD Customers Spring MVC + Spring Data JPA
Backend API REST con Spring Boot
Controladores Spring REST
Uso de Spring con Thymeleaf
API Specification
Registro de usuarios
Crear entidades JPA
Asociaciones en JPA
Asociaciones de entidades JPA
Integración con Vue
Consultas JPQL
Open API y cómo agregarlo en Spring Boot
Uso de Controladores REST
Repositorios reactivos
Inyección de dependencias
Introducción a Spring Boot
CRUD y JPA Repository
Inyección de dependencias
Vista en Spring MVC con Thymeleaf
Servicios en Spring
Operadores Reactivos
Configuración de Vue
Entidades JPA
Integración con Angular
API Specification
API Query By Example (QBE)
Controladores MVC
Anotaciones y mapeo en JPA
Consultas JPQL con @Query en Spring Data JPA
Repositorios Spring Data
Inyección de dependencias
Data JPA y Mail Starters
Configuración de Angular
Controladores Spring REST
Configuración de Controladores MVC
Consultas JPQL con @Query en Spring Data JPA
Actualizar datos de base de datos
Verificar token JWT en peticiones
Login de usuarios
Integración con React
Configuración de React
Todas las lecciones de SpringBoot
Accede a todas las lecciones de SpringBoot y aprende con ejemplos prácticos de código y ejercicios de programación con IDE web sin instalar nada.
Introducción A Spring Boot
Introducción Y Entorno
Spring Boot Starters
Introducción Y Entorno
Inyección De Dependencias
Introducción Y Entorno
Controladores Spring Mvc
Spring Web
Vista En Spring Mvc Con Thymeleaf
Spring Web
Controladores Spring Rest
Spring Web
Open Api Y Cómo Agregarlo En Spring Boot
Spring Web
Servicios En Spring
Spring Web
Clientes Resttemplate Y Restclient
Spring Web
Rxjava En Spring Web
Spring Web
Crear Entidades Jpa
Persistencia Spring Data
Asociaciones De Entidades Jpa
Persistencia Spring Data
Repositorios Spring Data
Persistencia Spring Data
Métodos Find En Repositorios
Persistencia Spring Data
Inserción De Datos
Persistencia Spring Data
Actualizar Datos De Base De Datos
Persistencia Spring Data
Borrar Datos De Base De Datos
Persistencia Spring Data
Consultas Jpql Con @Query En Spring Data Jpa
Persistencia Spring Data
Api Query By Example (Qbe)
Persistencia Spring Data
Api Specification
Persistencia Spring Data
Repositorios Reactivos
Persistencia Spring Data
Introducción E Instalación De Apache Kafka
Mensajería Asíncrona
Crear Proyecto Con Apache Kafka
Mensajería Asíncrona
Creación De Producers
Mensajería Asíncrona
Creación De Consumers
Mensajería Asíncrona
Kafka Streams En Spring Boot
Mensajería Asíncrona
Introducción A Spring Webflux
Reactividad Webflux
Spring Data R2dbc
Reactividad Webflux
Controlador Rest Reactivo Basado En Anotaciones
Reactividad Webflux
Controlador Rest Reactivo Funcional
Reactividad Webflux
Operadores Reactivos Básicos
Reactividad Webflux
Operadores Reactivos Avanzados
Reactividad Webflux
Cliente Reactivo Webclient
Reactividad Webflux
Introducción A Spring Security
Seguridad Con Spring Security
Seguridad Basada En Formulario En Mvc Con Thymeleaf
Seguridad Con Spring Security
Registro De Usuarios
Seguridad Con Spring Security
Login De Usuarios
Seguridad Con Spring Security
Verificar Token Jwt En Peticiones
Seguridad Con Spring Security
Seguridad Jwt En Api Rest Spring Web
Seguridad Con Spring Security
Seguridad Jwt En Api Rest Reactiva Spring Webflux
Seguridad Con Spring Security
Autenticación Y Autorización Con Anotaciones
Seguridad Con Spring Security
Testing Unitario De Componentes Y Servicios
Testing Con Spring Test
Testing De Repositorios Spring Data Jpa
Testing Con Spring Test
Testing Controladores Spring Mvc Con Thymeleaf
Testing Con Spring Test
Testing Controladores Rest Con Json
Testing Con Spring Test
Testing De Aplicaciones Reactivas Webflux
Testing Con Spring Test
Testing De Seguridad Spring Security
Testing Con Spring Test
Testing Con Apache Kafka
Testing Con Spring Test
Integración Con Angular
Integración Frontend
Integración Con React
Integración Frontend
Integración Con Vue
Integración Frontend
Objetivos de aprendizaje de esta lección
- Comprender qué es JPQL y cómo utilizar la anotación
@Query
para realizar consultas orientadas a objetos en una base de datos relacional. - Conocer cómo pasar parámetros a consultas JPQL y cómo usar parámetros con nombre para mejorar la legibilidad.
- Aprender cómo ejecutar consultas de actualización y borrado utilizando
@Query
y@Modifying
. - Conocer las funciones de agregado disponibles en JPQL, como
COUNT()
,AVG()
,SUM()
, etc. - Aprender cómo usar subconsultas en JPQL para realizar consultas más complejas y anidadas.
- Reconocer las consideraciones y precauciones al usar consultas nativas con la anotación
@Query(nativeQuery = true)
para interactuar con características específicas de la base de datos subyacente.