Как запретить JPA deleteByID () удалять родителя при удалении ребенка? - PullRequest
0 голосов
/ 02 апреля 2019

У меня есть приложение Spring mvc, в котором пользователи бронируют комнаты для совещаний. Когда я пытаюсь удалить бронирование с помощью deleteById (), пользователь, который принадлежит к бронированию, также удаляется. Как мне это предотвратить?

Объект бронирования:

package spe_booker.models;
import javax.persistence.*;
import javax.validation.constraints.NotNull;
import java.util.Date;
@Entity
public class Booking {
    @Id
    @GeneratedValue
    private Long id;
    @NotNull
    private Date startDateTime;
    @NotNull
    private Date endDateTime;
    @NotNull
    @ManyToOne(cascade = CascadeType.ALL)
    private Room room;
    @NotNull
    @ManyToOne(cascade = CascadeType.ALL)
    private User user;
    private Date creationDate;

    public Booking() {  }
    ...getters and setters...

Объект пользователя:

package spe_booker.models;
import javax.persistence.*;
import java.util.ArrayList;
import java.util.List;
@Entity
@Table(name = "user")
public class User {
    @Id
    @GeneratedValue
        private Long id;
    private String username;
    String name;
    private String password;
    private String faculty;
    private String role;
    private Boolean blacklisted;
    @Column(name = "enabled")
    public int enabled;
    @OneToMany(mappedBy = "user")
    private List<Booking> bookings = new ArrayList<>();
    ...getters and setters...

Репозиторий бронирования:

package spe_booker.Repositorys;

import org.springframework.data.repository.CrudRepository;
import org.springframework.stereotype.Repository;
import spe_booker.models.Booking;
import spe_booker.models.User;

import java.util.List;

@Repository
public interface BookingRepository extends CrudRepository<Booking, Long> {
    List<Booking> findAll();
    List<Booking> findBookingsByUser(User user);
}

Удалить вызов:

bookingRepository.deleteById(id);

Ответы [ 2 ]

0 голосов
/ 02 апреля 2019

CascadeType.ALL заставляет JPA каскадировать все операции (сохранение, удаление, обновление ....).Это означает, что когда вы удаляете / обновляете бронирование, оно удаляет / обновляет Комната и Пользователь объекты тоже

0 голосов
/ 02 апреля 2019

Измените каскад

@NotNull
@ManyToOne(cascade = CascadeType.ALL)
private User user;

на соответствующие значения.Вы меняете пользователя, а затем сохраняете бронирование и пользователя одновременно?Вы создаете заказы с пользователями одновременно?Если вы можете ответить на эти вопросы «нет», вы можете просто удалить (cascade = CascadeType.ALL).И вы должны спросить себя, почему каскады присутствуют в первую очередь!

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...