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 回答