Nhibernate ConFORM カスケードに問題があります。2 つのエンティティが存在します。
public class User : BaseEntity
{
public User(Role role)
{
this.Role = role;
}
protected User()
{
}
public virtual Role Role { get; protected set; }
}
および役割:
public class Role : BaseEntity
{
public Role()
{
this.Users = new HashedSet<User>();
}
public virtual ISet<User> Users { get; protected set; }
}
カスケード設定:
var relationalMapper = new ObjectRelationalMapper();
relationalMapper.TablePerConcreteClass(domainEntities);
relationalMapper.Patterns.PoidStrategies.Add(new NativePoidPattern());
relationalMapper.Cascade<User, Role>(Cascade.Persist);
relationalMapper.Cascade<Role, User>(Cascade.Persist);
この自動マッピングにより、次が得られます。
<class name="User" table="Users">
<id name="Id" type="Int32">
<generator class="native" />
</id>
<many-to-one name="Role" column="RoleId" cascade="save-update, persist" />
ロールを削除せずにユーザーを削除したい。ほとんどすべてのテストに合格しましたが、これは落ちます:
this.role = new Role();
this.user = new User(this.role) { Login = "memoryUser", Password = "memoryPass" }.SetIdTo(0);
role.Users.Add(user);
this.session.SaveOrUpdate(this.user);
repo.Delete(this.user);
var u = repo.GetByName("memoryUser");
u.Should().Be.Null();
エラー メッセージ: 削除されたユーザーを取得しようとすると表示されます (var u = repo.GetByName("memoryUser");)。
削除されたオブジェクトはカスケードによって再保存されます 関連付けから削除されたオブジェクトを削除します
この問題を解決するにはどうすればよいですか?