«Мягкое удаление» в Hibernate с сопоставлением OneToOneJAVA

Программисты JAVA общаются здесь
Ответить Пред. темаСлед. тема
Anonymous
 «Мягкое удаление» в Hibernate с сопоставлением OneToOne

Сообщение Anonymous »

Я использую шаблон под названием «мягкое удаление». Вместо удаления объекта я просто помечаю его как удаленный и предотвращаю его появление в результатах любого запроса, добавляя @Where(clause = "rmv = false")( — это имя столбца в базе данных, где я храню флаг).
В одном сценарии этот подход не работает.
Вот пример:

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

@Entity
@Table(name = "main_entity")
public class MainEntity {

@Id
private Long id;

@OneToOne(mappedBy = "main", cascade = CascadeType.ALL)
private DetailEntity detail;
}

@Entity
@Table(name = "detail_entity")
@Where(clause = "rmv = false")
public class DetailEntity{
@Id
private Long id;

@Column
private Boolean rmv = false;

@OneToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "main_id", nullable = false)
private MainEntity main;
}
Когда я пытаюсь получить экземпляр MainEntity из Hibernate с помощью mainEntityRepository.findById(id), я получаю объект с подробностями!= null . Несмотря на то, что запись в таблице Detail_entity имеет значение rmv = false.
Он выдает следующий SQL-запрос

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

select m.*, d.*
from main_entity m
left join detail_entity d
on m.id=d.main_id
where m.id=?
Я ожидаю, что в предложенииwhere будет условие d.rmv=false.
Мои вопросы:< /p>
  • Это ошибка или ожидаемое поведение?
  • Если это ожидаемое поведение, есть ли способ добиться желаемого эффекта?


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

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

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

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

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

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение
  • Запросы на мягкое удаление Hibernate возвращают удаленных внуков
    Anonymous » » в форуме JAVA
    0 Ответы
    24 Просмотры
    Последнее сообщение Anonymous
  • Мягкое удаление .net Core и уникальные ограничения с MySql
    Anonymous » » в форуме C#
    0 Ответы
    13 Просмотры
    Последнее сообщение Anonymous
  • EF Core: мягкое удаление с консервативной последовательности
    Anonymous » » в форуме C#
    0 Ответы
    9 Просмотры
    Последнее сообщение Anonymous
  • Мягкое удаление с консервативной последовательности
    Anonymous » » в форуме C#
    0 Ответы
    6 Просмотры
    Последнее сообщение Anonymous
  • Мягкое удаление с консервативной последовательности
    Anonymous » » в форуме C#
    0 Ответы
    2 Просмотры
    Последнее сообщение Anonymous

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