我有以下表格:
table A:
FOO (PK) | CLIENT (PK)
table B:
BAR (PK) | CLIENT (PK/FK) | FOO (FK)
PK - >主键
FK - >外键
A和B之间存在一对多的关系。 我不能简单地这样做:
class AMap
{
public AMap()
{
CompositeId().KeyReference(a => a.FOO)
.KeyReference(a => a.CLIENT);
HasMany(a => a.B);
}
}
class BMap
{
public BMap()
{
CompositeId().KeyReference(a => a.BAR)
.KeyReference(a => a.CLIENT);
References(a => a.A);
}
}
它将失败并出现以下异常:
外键(FKE7804EB3DA7EBD4B:B [FOO]))必须与引用的主键具有相同的列数(A [FOO,CLIENT])
是否可以使用流畅的nhibernate正确映射?
答案 0 :(得分:6)
找到解决方案:
HasMany(a => a.B).KeyColumns.Add("FOO", "CLIENT").Cascade.All();