5

我有两节课

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(); 
    } 
} 

我知道我需要为 Document 制作一个 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 关系的级联规则?谢谢安德鲁

Ps 很抱歉这个交叉帖子,但我需要尽快解决这个问题。

4

1 回答 1

0

我知道这是很久以前的事了(在计算机时代),你可能已经解决了这个问题。如果您没有或有类似问题的其他人看到这个,这里是:

我认为您需要创建一个实现IHasManyConvention. IClassConvention修改IClassMap<class>元素)目标。cascade不是有效的属性,<class>因此可以解释第一个错误。在您第二次尝试时,您正在重新映射集合,从而导致“重复集合”错误。

IHasManyConvention目标 an IOneToManyPart,您应该可以调用它,Cascade.AllDeleteOrphan()或者SetAttribute("cascade", "all-delete-orphan")如果前者由于某种原因不起作用。

编辑

对不起,我错过了你已经有一个 IHasManyConvention。由于您只想覆盖一种类型的约定,因此您应该只更改该Accept类型的约定中的方法。取而代之的是return true;,拉入您的DocumentConvention:

return target.EntityType == typeof(Document);

我相信OneToManyPart.EntityType引用包含实体类型(即Document)。

于 2009-05-07T16:59:26.587 回答