繁体   English   中英

MVC3无法创建新游戏

[英]MVC3 can't create new game

大家好,我遇到了以下错误:

ObjectContext 实例已被释放,不能再用于需要连接的操作。

错误针对以下内容:

  @Html.DisplayFor(modelItem => item.tblConsole.ConsoleName) "within the game table"

我的游戏 controller 中有以下代码:

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);  

并将其添加到我的 controller 的第一个创建部分:

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所需的所有数据,并且实体无需进行任何其他查询即可在视图中获取您请求的数据。

您可以在此处阅读有关EagerLazy加载的更多信息: http://msdn.microsoft.com/en-us/library/bb896272.aspx

此外,没有理由拥有 gamezoneDBEntities 的私有实例:

private gamezoneDBEntities db = new gamezoneDBEntities()

只需使用您在using块中创建的实例:

using (var db = new gamezoneDBEntities())

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM