【问题标题】:Update multiple records efficiently in code first首先在代码中有效地更新多条记录
【发布时间】:2017-01-13 06:02:31
【问题描述】:

我在操作中有以下场景,我想更新给定购物车中所有商品的数量。我将数组发回我的购物车项目的控制器,并希望在用户更新它们时更新数量。我怎样才能做到这一点?这就是我所在的位置。

这是我购物车的视图

@model SeniorProjectMVC.Models.ViewModels.CartViewModel

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

<h3>Your cart</h3>

@*<p>
    @Html.ActionLink("Create New", "Create")
</p>*@  

<div class="row header-row">
    <div class="large-1 columns">
        <h4> Quantity</h4>
    </div>
    <div class="large-5 columns text-center">
       <h4>Name</h4> 
    </div>
    <div class="large-1 columns">
      <h4>Price</h4>  
    </div>
    <div class="large-2 columns">
        <h4>In stock</h4>
    </div>
    <div class="large-3 columns"></div>
</div>
@{ 
    int CurrentIndex = 1;
}
@for (int i = 0; i < Model.CartArray.Length; i++)
{

    <div class="@(CurrentIndex % 2 == 0 ? "row primary-row" : "row alternate-row")">
        <div class="large-1 columns">
            @Html.EditorFor( m => m.CartArray[i].Quantity)
        </div>
        <div class="large-5 columns text-center">
            @Html.DisplayFor(m => m.CartArray[i].Sku.Product.Name)
        </div>
        <div class="large-1 columns">
            @*@Html.DisplayFor(m => m.CartArray[i].Sku.Product.Price)*@
            @String.Format("{0:c}", (Model.CartArray[i].Sku.Product.Price * Model.CartArray[i].Quantity))
        </div>
        <div class="large-2 columns">
            @( Model.CartArray[i].Sku.Quantity > 0 ? "In Stock" : "Out of stock")
        </div>
        <div class="large-3 columns">
            <ul class="button-group">
                @*<li class="button">@Html.ActionLink("Edit", "Edit", new { id = Model.CartArray[i].ID }, new { @class = "button primary" }) </li>*@
                <li class="button">@Html.ActionLink("Remove", "Remove", new { id = Model.CartArray[i].ID }, new { @class = "button primary" })</li>
            </ul>

            @*@Html.ActionLink("Details", "Details", new { id = item.ID }, new { @class = "button primary" }) |*@

        </div>
    </div>
    { CurrentIndex = CurrentIndex + 1; }
}
<div clsas="row">
    <div class="large-offset-8 columns">
        <h5 class="inline">Subtotal:</h5><h4 class="inline">@(Model.CartArray.Sum(p => (p.Sku.Product.Price * p.Quantity)).ToString("c"))</h4>
    </div>
</div>

<div class="row">
    <div class="medium-offset-8 medium-4 columns">
        <ul class="button-group">
            <li class="button">@Html.ActionLink("Update Quantities", "UpdateQuantities", "Cart", new { array = Model.CartArray }, new { @class = "button primary large" })</li>
            @if (Request.IsAuthenticated && User.Identity.IsAuthenticated)
            {
                <li class="button">@Html.ActionLink("Checkout", "Address", "Checkout", null, new { @class = "button primary large" })</li>
            }
            else
            {
                <li class="button secondary">You must sign in to checkout</li>
            }

        </ul>   
    </div>
</div>

这是我想将数量发布回控制器的操作,然后更新我的数据库上下文类。我不确定实现这一目标的最有效方法或方法是什么。

public ActionResult UpdateQuantities(Models.ViewModels.CartViewModel cartModel)
        {
            for (int i = 0; i < cartModel.CartArray.Length; i++)
            {
                //either update each record, or build a list to do one mass update.
                //This is where I am stuck
            }

            return View();
        }

【问题讨论】:

  • 您需要将您的元素包装在一个表单中并将表单提交给一个 POST 方法(并删除您的按钮,这是一个 GET 并且不会发回您的模型 - 查看@987654323 @ 属性它生成以理解 - 如果它这样做,它将发送回原始数据,而不是编辑的数据)。您还需要额外的隐藏输入来识别集合中的项目。
  • 所以我需要将它们包装在一个表单标签中,并为每个购物车项目的 ID 字段添加一个隐藏字段,对吗?
  • 是的。 CartViewModel 的任何属性,包括您希望在控制器中接收的 CartArray 集合的属性,都需要在 @using (Html.BeginForm(...)) 中使用表单控件
  • 你有什么我可以效仿的例子吗?我好像有问题
  • 你有什么问题?

标签: c# asp.net-mvc entity-framework ef-code-first linq-to-entities


【解决方案1】:

你应该可以使用这样的东西:

public ActionResult UpdateQuantities(Models.ViewModels.CartViewModel cartModel)
{
    // instantiate your database context if it's not already done
    using (var db = new Context())
    {
        for (int i = 0; i < cartModel.CartArray.Length; i++)
        {
            // update your records one at a time
            db.YourItems.Where(i => <your_criteria>).Member = NewValue;
        }

        // commit your changes only once at the end
        db.SaveChanges();

        return View();
    }

根据您的模型数据的结构,您还可以将上面的 for 循环替换为以下内容:

var items = db.YourItems.ToList();
items.ForEach(i => i.Member = cartModel.CartArray[i.Id].NewValue);

或者如果您必须更新多个属性:

items.ForEach(i => {
    i.Member1 = cartModel.CartArray[i.Id].Value1;
    i.Member2 = cartModel.CartArray[i.Id].Value2;
};

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2011-02-19
    • 2022-01-10
    • 2016-03-20
    相关资源
    最近更新 更多