Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/csharp/327.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# MVC3无法创建新游戏_C#_Asp.net_Asp.net Mvc 3 - Fatal编程技术网

C# MVC3无法创建新游戏

C# MVC3无法创建新游戏,c#,asp.net,asp.net-mvc-3,C#,Asp.net,Asp.net Mvc 3,大家好,我遇到了一个问题,我遇到了以下错误: ObjectContext实例已被释放,不能再用于需要连接的操作 错误指向以下方面: @Html.DisplayFor(modelItem => item.tblConsole.ConsoleName) "within the game table" 我的游戏控制器中有以下代码: using System; using System.Collections.Generic; using System.Data; using System.

大家好,我遇到了一个问题,我遇到了以下错误:

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 });
当你不点击create,每个用户都有自己的游戏帖子,但当我按下createnew时,这个代码就崩溃了

任何帮助都将不胜感激。请询问您是否需要了解更多信息

您需要在查询中包含console表数据

var Info = db.tblGames.Include(x => x.tblConsole).Where(UserInfo => UserInfo.UserName.Equals(User.Identity.Name)).ToList();
            return View(Info); 
返回的实体正在尝试延迟加载其他数据,但无法延迟加载,因为数据上下文已被释放。这是因为您将其包装在一个using块中。 通过使用Include,您可以在初始查询中加载所需的所有数据,实体将不需要进行任何其他查询来获取您在视图中请求的数据

您可以在此处阅读更多关于快速加载和延迟加载的内容:

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

private gamezoneDBEntities db = new gamezoneDBEntities()
只需使用在using块中创建的实例:


感谢您的尝试,这对x=>x.tblConsole有什么作用?Include还将从查询中的数据库中选择tblConsole数据。这将允许您访问页面上所需的所有数据,而无需EF进行其他查询和DbContexterrors@user1137472如果它抛出错误,那么您必须在应用程序的其他部分使用它。
using (var db = new gamezoneDBEntities())