Не могу удалить таблицу первичного ключа

Привет друзья у меня есть стол под названием Console и внутри он содержит один атрибут с именем ConsoleName это идентификатор этой таблицы и внешний ключ двух таблиц под названием Game и `Gamer. Проблема, с которой я сталкиваюсь, заключается в том, что когда я запускаю приложение, все работает нормально, и я могу вставить все нормально, но когда дело доходит до удаления КОНСОЛИ, я не могу удалить любую запись из таблицы консоли, так как это дает мне следующую ошибку:

Value cannot be null.
Parameter name: entity

Я использую MVC3 C#

Я попробовал СЛЕДУЮЩЕЕ:

[HttpPost, ActionName("Delete")]
    public ActionResult DeleteConfirmed(string id?)
    {            
        ConsoleTBL consoletbl = db.ConsoleTBLs.Find(id?);
        db.ConsoleTBLs.Remove(consoletbl);
        db.SaveChanges();
        return RedirectToAction("Index");
    }

Но это не работает.

Пожалуйста, если вам что-нибудь понадобится, дайте мне знать, я опубликую то, что вы просите за спасибо

РЕДАКТИРОВАТЬ: Консольный контроллер:

using System;
using System.Collections.Generic;
using System.Data;
using System.Data.Entity;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using MvcApplication1.Models;

namespace MvcApplication1.Controllers
{ 
    public class ConsoleController : Controller
    {
        private GameZoneEntities3 db = new GameZoneEntities3();

        //
        // GET: /Console/

        public ViewResult Index()
        {
            return View(db.ConsoleTBLs.ToList());
        }

        //
        // GET: /Console/Details/5

        public ViewResult Details(string id)
        {
            ConsoleTBL consoletbl = db.ConsoleTBLs.Find(id);
            return View(consoletbl);
        }

        //
        // GET: /Console/Create

        public ActionResult Create()
        {
            return View();
        } 

        //
        // POST: /Console/Create

        [HttpPost]
        public ActionResult Create(ConsoleTBL consoletbl)
        {
            if (ModelState.IsValid)
            {
                db.ConsoleTBLs.Add(consoletbl);
                db.SaveChanges();
                return RedirectToAction("Index");  
            }

            return View(consoletbl);
        }

        //
        // GET: /Console/Edit/5

        public ActionResult Edit(string id)
        {
            ConsoleTBL consoletbl = db.ConsoleTBLs.Find(id);
            return View(consoletbl);
        }

        //
        // POST: /Console/Edit/5

        [HttpPost]
        public ActionResult Edit(ConsoleTBL consoletbl)
        {
            if (ModelState.IsValid)
            {
                db.Entry(consoletbl).State = EntityState.Modified;
                db.SaveChanges();
                return RedirectToAction("Index");
            }
            return View(consoletbl);
        }

        //
        // GET: /Console/Delete/5

        public ActionResult Delete(string id)
        {
            ConsoleTBL consoletbl = db.ConsoleTBLs.Find(id);
            return View(consoletbl);
        }

        //
        // POST: /Console/Delete/5

        [HttpPost, ActionName("Delete")]
        public ActionResult DeleteConfirmed(string id)
        {            
            ConsoleTBL consoletbl = db.ConsoleTBLs.Find(id);
            db.ConsoleTBLs.Remove(consoletbl);
            db.SaveChanges();
            return RedirectToAction("Index");
        }

        protected override void Dispose(bool disposing)
        {
            db.Dispose();
            base.Dispose(disposing);
        }
    }
}

Индексная страница Консольной таблицы:

@model IEnumerable<MvcApplication1.Models.ConsoleTBL>

@{
    ViewBag.Title = "Index";
}

<h2>Index</h2>

<p>
    @Html.ActionLink("Create New", "Create")
</p>
<table>
    <tr>
        <th>
            ConsoleID
        </th>
        <th></th>
    </tr>

@foreach (var item in Model) {
    <tr>
        <td>
            @Html.DisplayFor(modelItem => item.ConsoleID)
        </td>
        <td>
            @Html.ActionLink("Edit", "Edit", new { /* id=item.PrimaryKey */ }) |
            @Html.ActionLink("Details", "Details", new { /* id=item.PrimaryKey */ }) |
            @Html.ActionLink("Delete", "Delete", new { /* id=item.PrimaryKey */ })
        </td>
    </tr>
}

</table>

Я установил первичный ключ для ссылок на "ConsoleID", но это тоже не сработало, просто чтобы вы знали, что я сделал

2 ответа

Вы запускали это в режиме отладки и входили в метод удаления?

Вы проверили, чтобы убедиться, что консоль существует?

[HttpPost, ActionName("Delete")]
public ActionResult DeleteConfirmed(string id)
{            
    ConsoleTBL consoletbl = db.ConsoleTBLs.Find(id);

    if( consoletbl != null)
    {
        db.ConsoleTBLs.Remove(consoletbl);
        db.SaveChanges();
    }
    else
    {
        // should probably return an error message
        throw new ArgumentNullException("Could not find a console with the id of " + id);
    }
    return RedirectToAction("Index");
}

Это должно вызвать исключение, если идентификатор, который вы передаете, не найден...

@model IEnumerable<MvcApplication1.Models.ConsoleTBL>

@{
    ViewBag.Title = "Index";
}

<h2>Index</h2>

<p>
    @Html.ActionLink("Create New", "Create")
</p>
<table>
    <tr>
        <th>
            ConsoleID
        </th>
        <th></th>
    </tr>

@foreach (var item in Model) {
    <tr>
        <td>
            @Html.DisplayFor(modelItem => item.ConsoleID)
        </td>
        <td>
            @Html.ActionLink("Edit", "Edit", new {  id=item.ConsoleID}) |
            @Html.ActionLink("Details", "Details", new {  id=item.ConsoleID}) |
            @Html.ActionLink("Delete", "Delete", new {  id=item.ConsoleID})
        </td>
    </tr>
}

</table>

Я предполагаю, что ConsoleID является основным идентификатором, поэтому я заменяю "PrimaryKey" этим свойством. /* */ используются для добавления комментариев в ваш код, и все что между ними не будет скомпилировано

По звуку, если вы удалите Console вы бы осиротили записи в Game а также Gamer таблицы (что не допускается, когда применяется внешний ключ). Таким образом, чтобы удалить Console вам придется либо удалить другие записи, используя их в качестве внешнего ключа, либо установить каскадное поведение, чтобы сделать это за вас.

Редактировать: Однако опубликованные вами ошибки означают, что вы пропустили параметр. Для удаления вы, скорее всего, будете иметь два действия, называемые "Удалить с одним представлением". одно действие удаления будет обычным запросом страницы (обычно для подтверждения удаления), а другое - тем, которое требует обратной передачи (которую вы разместили в своем вопросе).

Процесс, скорее всего, будет примерно таким

Get /consoles/details/1

нажмите кнопку удаления

Get /consoles/delete/1

Нажмите "Подтвердить" или "ОК" (в форме будет кнопка "Отправить").

Post /consoles/delete/1

Другие вопросы по тегам