Как удалить объект, на который есть ссылка, с помощью 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()
,