我正在提交一个包含用户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");
}
答案 0 :(得分:1)
我很惊讶你所做的事情不起作用,但这是一种回避这个问题的方法。
将public int UserID { get; set; }
添加到SeasonPass
并将其设置为分配关系,而不是设置User
。