无法定义两个对象之间的关系 - 为什么?

时间:2014-08-01 19:52:30

标签: c# asp.net asp.net-mvc entity-framework

我正在提交一个包含用户ID和竖线分隔数字的表单。

该模型如下所示:

public class SeasonPassData
{
    public int UserID { get; set; }
    public string SpaceNumbers { get; set; }
}

这是传递给这个控制器:

[HttpPost]
public ActionResult SignUp(SeasonPassData data)
{
    var user = db.Users.Find(data.UserID);
    List<SeasonPass> passes = new List<SeasonPass>();

    char[] delimiter = { '|' };
    var numbers = data.SpaceNumbers.Split(delimiter).Select(n => Convert.ToInt32(n)).ToArray();
    foreach(int number in numbers)
    {
        passes.Add(new SeasonPass { SpaceNumber=number, User = user });
    }
    passes.ForEach(p => db.SeasonPasses.Add(p));
    db.SaveChanges();

    return RedirectToAction("Confirmation", "Home");
}

应该创建和保存SeasonPasses:

public class SeasonPass
{
    public int ID { get; set; }
    public int SpaceNumber { get; set; }

    public virtual User User { get; set; }
}

然而,这个 - passes.ForEach(p => db.SeasonPasses.Add(p));一直在袭击这个例外:

  

发生了'System.InvalidOperationException'类型的异常   System.Data.Entity.dll但未在用户代码中处理

     

附加信息:两个对象之间的关系   无法定义,因为它们附加到不同的ObjectContext   对象。

我该如何解决?


我根据评论尝试了这些更改。它似乎仍然不起作用......

[HttpPost]
public ActionResult SignUp(SeasonPassData data)
{
    using(var context = new TTUContext())
    {
        var user = context.Users.Find(data.UserID);
        List<SeasonPass> passes = new List<SeasonPass>();

        char[] delimiter = { '|' };
        var numbers = data.SpaceNumbers.Split(delimiter).Select(n => Convert.ToInt32(n)).ToArray();
        foreach (int number in numbers)
        {
            passes.Add(new SeasonPass { SpaceNumber = number, User = user });
        }
        foreach (var pass in passes)
        {
            context.SeasonPasses.Add(pass);
        }
        context.SaveChanges();
    }

    return RedirectToAction("Confirmation", "Home");
}

1 个答案:

答案 0 :(得分:1)

我很惊讶你所做的事情不起作用,但这是一种回避这个问题的方法。

public int UserID { get; set; }添加到SeasonPass并将其设置为分配关系,而不是设置User