public class Parent
{
public virtual field1 { get; set;}
public virtual field2 { get; set;}
public virtual Child { get; set;
}
public class Child
{
public virtual childfield1 { get; set;} //composite primary key
public virtual childfield2 { get; set;} //composite primary key
public string somedescription { get; set;}
}
如果我只需要在一个字段上进行映射,我可以在父映射类中完成以下操作:
References(x => x.Child).ForeignKey("field1");
如果连接必须位于两个键field1和field2上,我该怎么办?
答案 0 :(得分:2)
public class Parent
{
public virtual Child Child { get; set; }
}
public class Child
{
public virtual int Key1 { get; set; } //composite primary key
public virtual int Key2 { get; set; } //composite primary key
public virtual string SomeDescription { get; set;}
}
// in ParentMap
References(p => p.Child).Columns.Add("child_key1", "child_key2");
// in Child
CompositeId()
.KeyProperty(x => x.Key1)
.KeyProperty(x => x.Key2);
并访问ChildKey1(列),不用加载孩子
var key1 = parent.Child.Key1;