0

次のエラーが表示されます:「削除されたオブジェクトはカスケードによって再保存されます (関連付けから削除されたオブジェクトを削除します)」

ajax 呼び出し全体を次のようにトリミングしました。

    [HttpPost]
    [UnitOfWork(Scope = FilterScope.Result)]
    public ActionResult SaveEditMode(long id, AddTrackedRowViewModel model, string editMode, List<string> elementNames, string provisionData)
    {    
       var cell = _supplementCoordinator.GetSupplement(id).TrackedTables.First(x => x.Name == model.Name).TrackedRows.First(x => x.Ordinal == model.Ordinal).TrackedCells.First(x => x.Name == "Detail");
       _supplementCoordinator.RemoveChildren(cell);

        return Json( new {Success = true});
    }



    public bool RemoveChildren(TrackedNode parentNode)
    {
        foreach (TrackedField trackedField in parentNode.ChildNodes)
        {
            _trackedFieldRepository.Delete(trackedField);
        }
        return true;
    }

私のマッピングは次のとおりです

        mapping.HasMany(x => x.ChildNodes).KeyColumn("ParentNodeId").Inverse();
        mapping.References(x => x.ParentNode);
4

1 に答える 1

1

エラーが示唆するように、親コレクションから子ノードを削除するだけです。

public bool RemoveChildren(TrackedNode parentNode)
    {
        foreach (TrackedField trackedField in new List<TrackField>(parentNode.ChildNodes))
        {
            _trackedFieldRepository.Delete(trackedField);
            _parentNode.Remove(trackField);
        }
        return true;
    }
于 2014-01-17T17:38:24.527 に答える