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模拟器!wepok... wepoke模拟器!wepoke有科技吗,wepoke软件收费是真的,扑克教程(有挂教程);致您一封...
微扑克ai机器人!wepoke... 微扑克ai机器人!wepoke辅助透视教程,德州aa poker有外挂,软件教程(有挂辅助挂)1、构...
德州微扑克辅助!wpk微扑克真... 德州微扑克辅助!wpk微扑克真的有挂吗,德州软件工具,德州论坛(有挂辅助挂),您好,德州微扑克辅助这...
wepok软件透明挂!德扑统计... wepok软件透明挂!德扑统计软件,德州辅助神器wpk,2025新版总结(有挂透明)1、wepok软...
智星德州菠萝有挂吗!微扑克有规... 智星德州菠萝有挂吗!微扑克有规律吗,德州ai智能系统,透明挂教程(有挂技巧)您好,智星德州菠萝有挂吗...
wepower辅助器!德州之星... wepower辅助器!德州之星app辅助器怎么用,wpk透视辅助哪里下载,规律教程(有挂黑科技)是一...
wepokeai代打!微扑克系... wepokeai代打!微扑克系统的发牌速度有多快,红龙扑克是真是假,可靠技巧(有挂透明)1、许多玩家...
aapoker猫腻!德州ai机... aapoker猫腻!德州ai机器人免费测试,微扑克有计算器,技巧教程(有挂教学),您好,德州ai机器...
wepoke辅助有挂!aapo... wepoke辅助有挂!aapoker辅助是真的吗,wpk透视辅助封号,第三方教程(有挂教学);小薇(...
微扑克辅助机器人!aapoke... 微扑克辅助机器人!aapoker是正规的吗,(wEpoKe)原生真的是有挂(详细辅助玩家教你)1、完...