1

正如实体框架所说,“代码优先”,这里我们首先使用代码......

public class BaseModel
{
    [Key]
    public Guid Id { get; set; }
    public DateTime DateCreated { get; set; }
    public DateTime DateChanged { get; set; }

    public BaseModel()
    {
        this.Id = Guid.NewGuid();
        this.DateCreated = DateTime.Now;
        this.DateChanged = DateTime.Now;
    }
}

public class Association: BaseModel
{
    public string Name { get; set; }
    public string Type { get; set; }

    public virtual List<Rule> Rules { get; set; }

    public Association()
        : base()
    {
    }
}

public class Rule: BaseModel
{
    [ForeignKey("Association")]
    public Guid AssociationId { get; set; }

    //[Required]
    public virtual Association Association { get; set; }

    //[Required]
    public string Name { get; set; }

    public string Expression { get; set; }

    public virtual List<Action> Actions { get; set; }

    public Rule()
        : base()
    {
    }
}

public class Action: BaseModel
{
    public string Name { get; set; }

    public string ActionType { get; set; }

    [ForeignKey("Rule")]
    public Guid RuleId { get; set; }

    public virtual Rule Rule { get; set; }

    public int Order { get; set; }

    public Action()
        : base()
    {
    }
}

所以这是我首先使用实体​​框架代码的四个模型类。每个都继承自基类,因此它们都有一个 Id Guid 作为主键。

一个协会有一个规则列表。(Rule has FK to Association)A Rule as 有一个动作列表。(行动有 FK 统治)

我想做的只是改变和保存最上层的类=协会。例如,在删除规则时,我希望这段代码能够工作:

 public ActionResult DeleteRule(Guid assId, Guid ruleId)
    {
        Association ass = this.DataContext.Associations.FirstOrDefault(a => a.Id == assId);
        ass.Rules.RemoveAll(r => r.Id == ruleId);

        this.DataContext.SaveChanges();

        return RedirectToAction("Index");
    }

在 context.savechanges 这给了我这个错误:'操作失败:关系无法更改,因为一个或多个外键属性不可为空。当对关系进行更改时,相关的外键属性将设置为空值。如果外键不支持空值,则必须定义新关系,必须为外键属性分配另一个非空值,或者必须删除不相关的对象。

删除操作时也会发生此错误。

有没有办法改变最上层(关联)对象并且只改变这个关联的东西。我不想说 context.Rules.remove(...) 或 context.actions.remove(...)

这是源代码:http : //server.thomasgielissen.be/files/mvctesting.zip 你需要 VS2012,所有 nuget 包都包含在 zip 中,你应该能够构建和运行项目。

提前感谢您的反馈!

格雷茨,托马斯

4

1 回答 1

0

如果你想解决这个问题,你应该通过联结表存储你的关系。我不认为你可以用这个模型实现你所需要的。

但是,如果您在实体之间放置连接表(或实体),则可以轻松删除子对象并更新父对象。

例如,在Association和之间放置一个连接实体Rule

public class AssociationRule: BaseModel
{
    public Guid AssociationId { get; set; }
    public Guid RuleId { get; set; }

    [ForeignKey("AssociationId")]
    public virtual Association Association { get; set; }
    [ForeignKey("RuleId")]
    public virtual Rule Rule { get; set; }        

    public Association()
        : base()
    {
    }
}

现在,您可以轻松地从任何关联中删除任何规则:

public ActionResult DeleteRule(Guid assId, Guid ruleId)
{
    AssociationRule assr = this.DataContext
        .AssociationRuless
        .FirstOrDefault(ar => ar.AssociationId == assId && ar.RuleId == ruleId);

    this.DataContext.AssociationRules.Remove(assr);
    this.DataContext.SaveChanges();

    return RedirectToAction("Index");
}
于 2013-08-03T07:59:32.273 回答