Не могу удалить таблицу первичного ключа
Привет друзья у меня есть стол под названием 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