ASP.NET MVC - 单表级联删除
创始人
2024-09-16 08:00:25
0

在ASP.NET MVC中,可以通过以下步骤实现单表级联删除:

  1. 首先,需要创建一个Controller来处理删除操作。假设我们有一个名为"Product"的实体类,对应的Controller为"ProductController"。
public class ProductController : Controller
{
    private readonly ApplicationDbContext _context;

    public ProductController(ApplicationDbContext context)
    {
        _context = context;
    }

    // GET: Product
    public ActionResult Index()
    {
        var products = _context.Products.ToList();
        return View(products);
    }

    // GET: Product/Delete/5
    public ActionResult Delete(int id)
    {
        var product = _context.Products.Find(id);
        if (product == null)
        {
            return HttpNotFound();
        }
        return View(product);
    }

    // POST: Product/Delete/5
    [HttpPost, ActionName("Delete")]
    [ValidateAntiForgeryToken]
    public ActionResult DeleteConfirmed(int id)
    {
        // 查找要删除的产品
        var product = _context.Products.Find(id);

        // 删除与产品相关的相关实体
        // 这里假设有一个"Order"实体类,它与产品相关联
        var orders = _context.Orders.Where(o => o.ProductId == product.Id);
        _context.Orders.RemoveRange(orders);

        // 删除产品
        _context.Products.Remove(product);

        // 保存更改
        _context.SaveChanges();

        return RedirectToAction("Index");
    }
}
  1. 在视图中,创建一个"Delete"视图以显示要删除的产品的详细信息,并提供一个删除按钮。
@model YourProjectName.Models.Product

@{
    ViewBag.Title = "Delete";
    Layout = "~/Views/Shared/_Layout.cshtml";
}

Delete

Are you sure you want to delete this product?

Product


@Html.DisplayNameFor(model => model.Name)
@Html.DisplayFor(model => model.Name)
@using (Html.BeginForm()) { @Html.AntiForgeryToken()
| @Html.ActionLink("Back to List", "Index")
}

这样,当用户点击删除按钮时,将会执行"DeleteConfirmed"方法,该方法会删除与产品相关联的任何实体,并最终删除产品自身。

相关内容

热门资讯

第五俱乐部(wepoke真的)... 第五俱乐部(wepoke真的)外挂透明挂辅助器(辅助挂)可靠技巧(有挂细节)-哔哩哔哩;实战中需综合...
五个检测!wpk怎么下载ios... 五个检测!wpk怎么下载ios(外挂被实锤)原来真的有挂(有挂实锤)-哔哩哔哩;支持2-10人实时对...
2个挂!德扑之星电脑版(数据解... 2个挂!德扑之星电脑版(数据解析)透视辅助(有挂分析)-哔哩哔哩关于德扑之星电脑的基本介绍、功能特点...
4修改器!白金岛放炮罚有挂吗(... 4修改器!白金岛放炮罚有挂吗(辅助挂)太坑了其实真的有挂(确实有挂)-哔哩哔哩是一款可以让一直输的玩...
3个规律!用ai外挂打德州有用... 3个规律!用ai外挂打德州有用(辅助机器人)透视(真的有挂)-哔哩哔哩这是由厦门游乐互动科技有限公司...
第3新版(德扑手机上)外挂透明... 第3新版(德扑手机上)外挂透明挂辅助APP(辅助挂)安装教程(有挂规律)-哔哩哔哩;wpk透视辅助官...
第4个助手!德扑ai软件(牌力... 第4个助手!德扑ai软件(牌力分析软件)辅助透视(有挂讲解)-哔哩哔哩1、玩家可以在德扑ai软件软件...
第九计算器!网易棋牌一直输为什... 第九计算器!网易棋牌一直输为什么(辅助挂)太坑了其实真的有挂(有挂解密)-哔哩哔哩1、任何德州ai辅...
第四个技巧!微扑克app(伙牌... 第四个技巧!微扑克app(伙牌技巧)透视辅助(的确有挂)-哔哩哔哩;wpk透视辅助官方版是专为公司和...
第6专用(德州免费)外挂透明挂... 1、第6专用(德州免费)外挂透明挂辅助神器(透视)德州论坛(有挂详情)-哔哩哔哩;详细教程。2、德州...