Spring Data JPA OneToOne ON DELETE SET NULLJAVA

Программисты JAVA общаются здесь
Ответить Пред. темаСлед. тема
Anonymous
 Spring Data JPA OneToOne ON DELETE SET NULL

Сообщение Anonymous »

У меня есть две сущности для RfidTags и Persons. Один RfidTag присваивается одному лицу. Один человек может иметь один RfidTag. Если я удалю человека, у которого есть RfidTag, назначенный RfidTag не должен быть удален, он должен остаться в базе данных, но значение person_id должно быть установлено в NULL. У меня уже есть такой SQL, но он не работает:

Код: Выделить всё

ALTER TABLE `rfid_tags`
ADD CONSTRAINT `FK_Rfid_Tag_Person`
FOREIGN KEY (`person_id`) REFERENCES `persons`(`id`)
ON DELETE SET NULL;
А вот мои сущности. Я уже много искал и пробовал разные вещи, такие как изменение CascadeTypes или добавление @OnDelete(onDeleteAction=SET_NULL), но ничего не работает. Либо RfidTag также будет удален (чего я не хочу), либо я получу ошибку типа: org.hibernate.TransientObjectException: постоянный экземпляр ссылается на несохраненный временный экземпляр PersonEntity (сохраните временный экземпляр перед очисткой)

Код: Выделить всё

@Getter
@Setter
@Entity
@Table(name = "persons")
public class PersonEntity {
@Id
@GeneratedValue(strategy = GenerationType.UUID)
private String id;

@Column(nullable = false)
private String firstName;

@Column(nullable = false)
private String lastName;

@OneToOne(fetch = FetchType.LAZY, mappedBy = "person", cascade = CascadeType.DETACH)
private RfidEntity rfid;
}

Код: Выделить всё

@Getter
@Setter
@Entity
@Table(name = "rfid_tags")
public class RfidEntity {

@Id
@GeneratedValue(strategy = GenerationType.UUID)
private String id;

@Column(nullable = false)
private String label;

@OneToOne(fetch = FetchType.LAZY)
@JoinColumn(name="person_id", referencedColumnName="id")
private PersonEntity person;
}
Я уже много искал и пробовал разные вещи, такие как изменение CascadeTypes или добавление @OnDelete(onDeleteAction=SET_NULL)

Подробнее здесь: https://stackoverflow.com/questions/793 ... e-set-null
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение
  • Spring Data JPA OneToOne ON DELETE SET NULL
    Anonymous » » в форуме JAVA
    0 Ответы
    23 Просмотры
    Последнее сообщение Anonymous
  • Как использовать функцию Set Set State Set Set Satwerive AMD (ADL) (для программного переворачивания)
    Anonymous » » в форуме C#
    0 Ответы
    44 Просмотры
    Последнее сообщение Anonymous
  • Android Monhofit Post Type Data Data Wations Data Null Null
    Anonymous » » в форуме Android
    0 Ответы
    47 Просмотры
    Последнее сообщение Anonymous
  • Android Monhofit Post Type Data Data Wations Data Null Null
    Anonymous » » в форуме Android
    0 Ответы
    38 Просмотры
    Последнее сообщение Anonymous
  • Spring Boot / JPA: «Невозможно найти дескриптор объекта» после установки взаимосвязи @onetoone в NULL с QueryDsl
    Anonymous » » в форуме JAVA
    0 Ответы
    2 Просмотры
    Последнее сообщение Anonymous

Вернуться в «JAVA»