Spring Boot

SpringBoot

Tutorial SpringBoot: Borrar datos de base de datos

Spring Boot borrar datos: eliminación de registros. Aprende a eliminar registros en Spring Boot con ejemplos prácticos y detallados.

Introducción

Eliminar datos de una base de datos es una operación común en muchas aplicaciones. 

Spring Data JPA simplifica este proceso proporcionando métodos como deleteById y deleteAll, que permiten a los desarrolladores gestionar la eliminación de registros de manera eficiente y segura. 

Esta lección explorará cómo utilizar estos métodos para eliminar registros individuales o múltiples de una base de datos.

Método deleteById

Propósito

El método deleteById se utiliza para eliminar un registro específico de la base de datos utilizando su ID. Es útil cuando conoces el identificador único del objeto que deseas eliminar.

Uso

Para utilizar deleteById, simplemente pasas el ID del objeto que deseas eliminar al método proporcionado por el repositorio. Este método maneja la eliminación sin necesidad de cargar el objeto en memoria, lo que lo hace eficiente.

Ejemplo de Código

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

@Service
public class UserService {

    @Autowired
    private UserRepository userRepository;

    public void deleteUserById(Long id) {
        userRepository.deleteById(id);
    }
}

Método deleteAll

Propósito

El método deleteAll se usa para eliminar todos los registros de un tipo de entidad de la base de datos. Este método puede ser muy útil para operaciones de limpieza o cuando se necesitan restablecer datos durante las pruebas.

Uso

deleteAll puede ser utilizado sin parámetros para eliminar todas las entidades almacenadas. También puede sobrecargarse para aceptar una colección de entidades, eliminando selectivamente un conjunto específico de registros.

Ejemplo de Código

@Service
public class ProductService {

    @Autowired
    private ProductRepository productRepository;

    public void deleteAllProducts() {
        productRepository.deleteAll();
    }
}

Métodos de borrado personalizados

En un repositorio de Spring Data JPA es posible crear métodos derivados que borren datos utilizando algún filtro.

Ejemplo de entidad Reservation asociada a una entidad Book:

@Entity

public class Reservation {

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;
    
    // ....
    
    @ManyToOne
    private Book book;
    
}

Ejemplo de método personalizado para borrar reservas filtrando por libro:

package com.certidevs.repository;

import com.certidevs.model.Reservation;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.transaction.annotation.Transactional;

public interface ReservationRepository extends JpaRepository<Reservation, Long> {

    @Transactional
    void deleteByBookId(Long bookId);
}

Este método puede ser invocado antes de intentar borrar un libro, así se eliminan primero las reservas del libro, evitando problemas de integridad referencial.

Habría que aplicar esta misma estrategia a cualquier otra asociación que haya con libro si queremos poder borrar el libro.

Una alternativa es desasociar entidades relacionadas con libro antes de borrar el libro.

Consideraciones

  • Rendimiento: deleteAll puede ser costoso en términos de rendimiento, especialmente si hay un gran número de registros. Es recomendable usarlo con cautela en entornos de producción.
  • Implicaciones de integridad de datos: Eliminar registros puede tener efectos en cascada, especialmente si existen restricciones de integridad como claves foráneas. Asegúrate de entender cómo JPA maneja las eliminaciones en relación con otras entidades relacionadas.

Conclusión

deleteById y deleteAll son herramientas poderosas en Spring Data JPA que permiten a los desarrolladores gestionar la eliminación de datos de manera eficaz. Comprender cómo y cuándo utilizar estos métodos es esencial para manejar la persistencia de datos de manera responsable y efectiva en aplicaciones basadas en Spring.

Certifícate en SpringBoot con CertiDevs PLUS

Ejercicios de esta lección Borrar datos de base de datos

Evalúa tus conocimientos de esta lección Borrar datos de base de datos con nuestros retos de programación de tipo Test, Puzzle, Código y Proyecto con VSCode, guiados por IA.

Web y Test Starters

Spring Boot
Puzzle

Entidades JPA

Spring Boot
Test

Repositorios reactivos

Spring Boot
Test

Inserción de datos

Spring Boot
Test

Borrar datos de base de datos

Spring Boot
Test

Controladores Spring MVC

Spring Boot
Código

Backend API REST con Spring Boot

Spring Boot
Proyecto

Operadores Reactivos

Spring Boot
Puzzle

Controladores Spring REST

Spring Boot
Código

Uso de Spring con Thymeleaf

Spring Boot
Puzzle

Crear entidades JPA

Spring Boot
Código

Registro de usuarios

Spring Boot
Test

CRUD y JPA Repository

Spring Boot
Puzzle

Anotaciones y mapeo en JPA

Spring Boot
Puzzle

Integración con Vue

Spring Boot
Test

Consultas JPQL con @Query en Spring Data JPA

Spring Boot
Test

Open API y cómo agregarlo en Spring Boot

Spring Boot
Puzzle

Uso de Controladores REST

Spring Boot
Puzzle

API Specification

Spring Boot
Puzzle

Inyección de dependencias

Spring Boot
Test

Introducción a Spring Boot

Spring Boot
Test

Consultas JPQL con @Query en Spring Data JPA

Spring Boot
Puzzle

API Query By Example (QBE)

Spring Boot
Puzzle

Inyección de dependencias

Spring Boot
Código

Vista en Spring MVC con Thymeleaf

Spring Boot
Test

Servicios en Spring

Spring Boot
Código

Configuración de Vue

Spring Boot
Puzzle

Integración con Angular

Spring Boot
Test

API Query By Example (QBE)

Spring Boot
Test

API Specification

Spring Boot
Test

Controladores MVC

Spring Boot
Test

Métodos find en repositorios

Spring Boot
Test

Repositorios Spring Data

Spring Boot
Test

Inyección de dependencias

Spring Boot
Puzzle

Data JPA y Mail Starters

Spring Boot
Test

Configuración de Angular

Spring Boot
Puzzle

Controladores Spring REST

Spring Boot
Test

Configuración de Controladores MVC

Spring Boot
Puzzle

Asociaciones de entidades JPA

Spring Boot
Código

Actualizar datos de base de datos

Spring Boot
Test

Identificadores y relaciones JPA

Spring Boot
Puzzle

Verificar token JWT en peticiones

Spring Boot
Test

Login de usuarios

Spring Boot
Test

Integración con React

Spring Boot
Test

Configuración de React

Spring Boot
Puzzle

Asociaciones en JPA

Spring Boot
Test

Consultas JPQL

Spring Boot
Código

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

Spring Boot

Introducción Y Entorno

Spring Boot Starters

Spring Boot

Introducción Y Entorno

Inyección De Dependencias

Spring Boot

Introducción Y Entorno

Controladores Spring Mvc

Spring Boot

Spring Web

Vista En Spring Mvc Con Thymeleaf

Spring Boot

Spring Web

Controladores Spring Rest

Spring Boot

Spring Web

Open Api Y Cómo Agregarlo En Spring Boot

Spring Boot

Spring Web

Servicios En Spring

Spring Boot

Spring Web

Crear Entidades Jpa

Spring Boot

Persistencia Con Spring Data

Asociaciones De Entidades Jpa

Spring Boot

Persistencia Con Spring Data

Repositorios Spring Data

Spring Boot

Persistencia Con Spring Data

Métodos Find En Repositorios

Spring Boot

Persistencia Con Spring Data

Inserción De Datos

Spring Boot

Persistencia Con Spring Data

Actualizar Datos De Base De Datos

Spring Boot

Persistencia Con Spring Data

Borrar Datos De Base De Datos

Spring Boot

Persistencia Con Spring Data

Consultas Jpql Con @Query En Spring Data Jpa

Spring Boot

Persistencia Con Spring Data

Api Query By Example (Qbe)

Spring Boot

Persistencia Con Spring Data

Repositorios Reactivos

Spring Boot

Persistencia Con Spring Data

Api Specification

Spring Boot

Persistencia Con Spring Data

Integración Con React

Spring Boot

Integración Frontend

Integración Con Vue

Spring Boot

Integración Frontend

Integración Con Angular

Spring Boot

Integración Frontend

Registro De Usuarios

Spring Boot

Seguridad Con Spring Security

Login De Usuarios

Spring Boot

Seguridad Con Spring Security

Verificar Token Jwt En Peticiones

Spring Boot

Seguridad Con Spring Security

En esta lección

Objetivos de aprendizaje de esta lección

  • Borrar un objeto utilizando deleteById()
  • Borrar múltiples objetos utilizando deleteAll()