У меня есть два класса
public class Document
{
public virtual int Id { get; set; }
public virtual IList<File> Files { get; set; }
}
public class File
{
public virtual int Id { get; protected set; }
public virtual Document Document { get; set; }
}
со следующим соглашением:
public class HasManyConvention : IHasManyConvention
{
public bool Accept(IOneToManyPart target)
{
return true;
}
public void Apply(IOneToManyPart target)
{
target.Cascade.All();
}
}
и эти переопределения карт
public class DocumentMappingOverride : IAutoMappingOverride<Document>
{
public void Override(AutoMap<Document> mapping)
{
mapping.HasMany(x => x.Files)
.Inverse()
// this line has no effect
.Cascade.AllDeleteOrphan();
}
}
public class FileMappingOverride : IAutoMappingOverride<File>
{
public void Override(AutoMap<File> mapping)
{
mapping.References(x => x.Document).Not.Nullable();
}
}
Я понимаю, что мне нужно сделать IClassConvention для документа, чтобы
изменить каскадное поведение, однако я не могу заставить это работать!
Если я сделаю это:
public class DocumentConvention : IClassConvention
{
public bool Accept(IClassMap target)
{
return target.EntityType == typeof(Document);
}
public void Apply(IClassMap target)
{
target.SetAttribute("cascade", "all-delete-orphan");
}
}
Я получаю: «Атрибут« каскад »не объявлен».
Если я сделаю это:
public class DocumentConvention : IClassConvention
{
public bool Accept(IClassMap target)
{
return target.EntityType == typeof(Document);
}
public void Apply(IClassMap target)
{
target.HasMany<Document, File>(x => x.Files)
.Inverse()
.Cascade.AllDeleteOrphan();
}
}
Тогда я получаю:
"Duplicate collection role mapping Document.Files"
так что я добавил:
mapping.IgnoreProperty(x => x.Files);
для сопоставления моего документа, но тогда Файлы всегда пустые.
Что я делаю неправильно?
Как я могу переопределить правило каскадирования для одного отношения HasMany?
Спасибо
Андрей
P.s. Извините за кросс-пост с this , но мне нужно, чтобы это было решено как можно скорее.