不能删除主键表
本文关键字:删除 不能 | 更新日期: 2023-09-27 18:28:30
嗨,朋友们,我有一个名为Console
的表,里面有一个属性ConsoleName
,这是这个表的ID,也是两个表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>
我已经将actionlink上的主键设置为"ConsoleID",但这也不起作用,只是为了告诉你我做了什么
如果删除Console
,则会孤立Game
和Gamer
表中的记录(强制使用外键时不允许这样做)。因此,为了删除Console
,您必须删除将其用作外键的其他记录,或者设置级联行为来为您执行此操作。
编辑:但是,您发布的错误似乎暗示您缺少一个参数。对于删除,您可能会有两个名为Delete的操作和一个View。一个删除操作将是一个正常的页面请求(通常用于确认删除),另一个操作将是需要回发的操作(您在问题中发布了该操作)。
这个过程可能类似于
Get /consoles/details/1
单击删除按钮
Get /consoles/delete/1
按下确认或OK(这将是表单中的提交按钮)
Post /consoles/delete/1
您是否在调试模式下运行此程序并进入delete方法?
你检查过以确保控制台bl存在吗?
[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");
}
如果找不到您传递的id,这应该会引发异常。。。
@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是主id,所以我用这个属性替换"PrimaryKey"。/**/用于在代码中放置注释,它们之间的任何内容都不会被编译