MVC3可以';t创造新的游戏
本文关键字:创造 游戏 可以 MVC3 | 更新日期: 2023-09-27 18:30:10
嗨,大家有问题,收到以下错误:
ObjectContext实例已被释放,不能再用于需要连接的操作。
并且错误指向以下内容:
@Html.DisplayFor(modelItem => item.tblConsole.ConsoleName) "within the game table"
我的游戏控制器中有以下代码:
using System;
using System.Collections.Generic;
using System.Data;
using System.Data.Entity;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using GameTest.Models;
namespace GameTest.Controllers
{
public class GameController : Controller
{
private gamezoneDBEntities db = new gamezoneDBEntities();
//
// GET: /Game/
public ViewResult Index()
{
using (var db = new gamezoneDBEntities())
{
var Info = db.tblGames.Where(UserInfo => UserInfo.UserName.Equals(User.Identity.Name)).ToList();
return View(Info);
}
}
//
// GET: /Game/Details/5
public ViewResult Details(int id)
{
tblGame tblgame = db.tblGames.Find(id);
return View(tblgame);
}
//
// GET: /Game/Create
public ActionResult Create()
{
ViewBag.ConsoleNameIDFK = new SelectList(db.tblConsoles, "ConsoleName", "ConsoleName");
return View(new tblGame { UserName = @User.Identity.Name });
}
//
// POST: /Game/Create
[HttpPost]
public ActionResult Create(tblGame tblgame)
{
if (ModelState.IsValid)
{
db.tblGames.Add(tblgame);
db.SaveChanges();
return RedirectToAction("Index");
}
ViewBag.ConsoleNameIDFK = new SelectList(db.tblConsoles, "ConsoleName", "ConsoleName", tblgame.ConsoleNameIDFK);
return View(tblgame);
}
//
// GET: /Game/Edit/5
public ActionResult Edit(int id)
{
tblGame tblgame = db.tblGames.Find(id);
ViewBag.ConsoleNameIDFK = new SelectList(db.tblConsoles, "ConsoleName", "ConsoleName", tblgame.ConsoleNameIDFK);
return View(tblgame);
}
//
// POST: /Game/Edit/5
[HttpPost]
public ActionResult Edit(tblGame tblgame)
{
if (ModelState.IsValid)
{
db.Entry(tblgame).State = EntityState.Modified;
db.SaveChanges();
return RedirectToAction("Index");
}
ViewBag.ConsoleNameIDFK = new SelectList(db.tblConsoles, "ConsoleName", "ConsoleName", tblgame.ConsoleNameIDFK);
return View(tblgame);
}
//
// GET: /Game/Delete/5
public ActionResult Delete(int id)
{
tblGame tblgame = db.tblGames.Find(id);
return View(tblgame);
}
//
// POST: /Game/Delete/5
[HttpPost, ActionName("Delete")]
public ActionResult DeleteConfirmed(int id)
{
tblGame tblgame = db.tblGames.Find(id);
db.tblGames.Remove(tblgame);
db.SaveChanges();
return RedirectToAction("Index");
}
protected override void Dispose(bool disposing)
{
db.Dispose();
base.Dispose(disposing);
}
}
}
我在索引中使用了这个代码,所以每个游戏对发布游戏的用户来说都是唯一的:
var Info = db.tblGames.Where(UserInfo => UserInfo.UserName.Equals(User.Identity.Name)).ToList();
return View(Info);
并在我的控制器的第一个创建部分添加了这个:
return View(new tblGame { UserName = @User.Identity.Name });
当你不点击创建时,这个代码确实有效,每个用户都有自己的游戏帖子,但当我按下创建新的时,它会崩溃
如有任何帮助,我们将不胜感激。请询问您是否需要了解更多
您需要Include
查询中的控制台表数据。
var Info = db.tblGames.Include(x => x.tblConsole).Where(UserInfo => UserInfo.UserName.Equals(User.Identity.Name)).ToList();
return View(Info);
您返回的实体正在尝试在其他数据中lazy load
,但无法,因为数据上下文已被释放。这是因为您将它封装在using
块中。通过使用Include
,您就是初始查询中所需的所有数据的Eager Loading
,实体将不需要进行任何额外的查询来获得视图中所请求的数据。
您可以在此处阅读有关Eager
和Lazy
加载的更多信息:http://msdn.microsoft.com/en-us/library/bb896272.aspx
此外,没有理由拥有GamezoneDBEnties:的私有实例
private gamezoneDBEntities db = new gamezoneDBEntities()
只需使用您在using
块中创建的实例:
using (var db = new gamezoneDBEntities())