Как удалить объект, на который есть ссылка, с помощью FluentNHibernate (например, "удаленный объект будет восстановлен каскадом")

Ошибка, которую я получаю, является обычной, но в сценарии я не нашел ответов, которые бы соответствовали моему сценарию:

Объекты:

Школьный учитель

Отображения:

School:  mapping.HasMany(x => x.Students).Cascade.AllDeleteOrphan();
Student: 
      mapping.References(x => x.Teacher).Not.Nullable().Cascade.SaveUpdate();
      mapping.References(x => x.School).Not.Nullable().Cascade.SaveUpdate();
Teacher: 
      mapping.References(x => x.School).Not.Nullable().Cascade.SaveUpdate();
      mapping.HasMany(x => x.Students).Cascade.All().Inverse();

Сценарий: ученик связан со школой, в которой нет других учеников или учителей. Если я хочу связать учащегося с другой школой, я хочу удалить осиротевшую школу.

if (oldSchool.Students.Count == 1 && oldSchool.Teachers.Count == 0)
{
    //delete it
    //oldSchool.Students.Remove(student);
    student.School = null;

    _schoolRepository.Delete(oldSchool);
}

Здесь происходит то, что, когда я иду, чтобы сохранить "ученик", я получаю, что страшный "удаленный объект будет спасен путем каскадной" ошибки.

Как всегда, любая помощь с благодарностью.

1 ответ

Как выглядят остальные ваши сопоставления? Каково обратное положение между школой и учеником?

Пытаться mapping.HasMany(x => x.Students).Cascade.AllDeleteOrphan().Inverse(),

Другие вопросы по тегам