The model item passed into the dictionary is of type 'System.Data.Entity.DynamicProxies.Object

岁酱吖の 提交于 2019-11-30 22:33:36

This code:

Move result = (from move in db.Moves
         where move.UserId == currentUserId
         select move).FirstOrDefault();
return View(result);

tries to return a single result. It's complaining that it wants a sequence of results. So you could just use:

var results = (from move in db.Moves
               where move.UserId == currentUserId
               select move).Take(1).ToList();
return View(results);

Or:

Move result = (from move in db.Moves
         where move.UserId == currentUserId
         select move).FirstOrDefault();
return View(new[] { result });

I would personally get rid of the query expression here, by the way - it's make the code more complicated than it needs to be. For example, you could rewrite my first option as:

var results = db.Moves.Where(move => move.UserId == currentUserId)
                      .Take(1)
                      .ToList();
return View(results);

Or even:

return View(db.Moves.Where(move => move.UserId == currentUserId)
              .Take(1).ToList());
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!