次のエンティティがあります: Project、ProjectMapping、および User。多対多です。マッピングは次のとおりです。
public ProjectMembershipMapping()
{
Property(pm => pm.IsAccepted, prop => prop.NotNullable(true));
Property(pm => pm.Permission, prop => prop.NotNullable(true));
ManyToOne(pm => pm.Member, mapping =>
{
mapping.Lazy(LazyRelation.NoLazy);
mapping.Cascade(Cascade.All);
});
ManyToOne(pm => pm.Project, mapping =>
{
mapping.Lazy(LazyRelation.NoLazy);
mapping.Cascade(Cascade.All);
});
ComposedId(pm =>
{
pm.ManyToOne(prop => prop.Member);
pm.ManyToOne(prop => prop.Project);
});
}
public ProjectMapping()
{
Set(proj => proj.Members,
mapping =>
{
mapping.Lazy(CollectionLazy.NoLazy);
mapping.Inverse(false);
mapping.Cascade(Cascade.All);
mapping.Table("ProjectMembership");
mapping.Key(k => k.Column("Project"));
},
action => action.OneToMany()
);
}
public class DevcoopUserMapping : ClassMapping<DevcoopUser>
{
Bag(user => user.ProjectMemberships,
mapping =>
{
mapping.Lazy(CollectionLazy.NoLazy);
mapping.Inverse(false);
mapping.Cascade(Cascade.All);
mapping.Table("ProjectMembership");
mapping.Key(k => k.Column("Member"));
},
action => action.OneToMany());
}
ユーザーは多くのプロジェクトのメンバーになることができます。ここで、彼をプロジェクトから退会させるとしましょう。ISession オブジェクトで ProjectMembership オブジェクトを削除するだけで、次のようにスローされます。
deleted object would be re-saved by cascade (remove deleted object from associations)[devcoop.Daos.ProjectMembership#devcoop.Daos.ProjectMembership]
一方、この ProjectMembership インスタンスを Project および User から最初に削除しようとすると (提案されたように関連付けから削除します)、例外が発生します。
could not delete collection: [devcoop.Daos.Project.Members#1][SQL: UPDATE ProjectMembership SET Project = null WHERE Project = @p0]
誰でも助けることができますか?おそらく、マッピングの周りで何かを台無しにしましたが、これが何であるかわかりませんでした。