ASP.NET MVC控制器中的持久数据

时间:2018-10-20 08:18:50

标签: c# asp.net-mvc

我想使用同一视图在数据库中插入和更新数据。

当我处于“编辑模式”时,我需要知道该版本前后的值是什么(要知道已更改的内容并根据该值执行操作)。

我无法在模型中存储“编辑前”数据,因为没有映射,并且由于在get和post之间创建了新实例,因此无法将数据存储在控制器中。

例如,我完全不知道使用静态类或隐藏字段,但这对我来说不是一个好习惯。

如何以适当的方式实现这一目标?

谢谢

1 个答案:

答案 0 :(得分:3)

您可以在
中查看较早的数据   var data = context.DEMO_MAST.Where(x => x.ID == model.ID).FirstOrDefault();  和 Model 中的新数据,只需使用If条件,您就可以通过一种方法同时完成 AddEdit 这两项。

AddEdit方法

 public int AddOrEdit(DEMO_MAST model)
            {
                try
                {
                    var data = context.DEMO_MAST.Where(x => x.ID == model.ID).FirstOrDefault();
                    if (data == null)
                    {
                        model.CREATED_ON = DateTime.Now;
                        this.context.DEMO_MAST.Add(model);
                    }
                    else
                    {
                        model.MODIFIED_ON = DateTime.Now;
                        this.context.Entry(data).CurrentValues.SetValues(model);
                    }
                    int flg = this.context.SaveChanges();
                    return flg;
                }
                catch (Exception ex)
                {
                    return 0;
                }
            }

查找

public DEMO_MAST Find(int ID)
{
  return context.DEMO_MAST.where(x=>x.ID==ID).FirstorDefault();
}

控制器

[HttpGet]
public ActionResult Index(int ID)
{
   DEMO_MAST model=new DEMO_MAST();
  if(ID>0)
  {
     model=Find(ID);   
  } 
return View(model);
}

[HttpPost]
public ActionResult Index(DEMO_MAST model)
{
  if(ModelState.IsValid)
  {
     int i = AddEdit(model); 
     if(i>0) 
     {
       ViewBag.Message="Record AddEdit Successfully";
     }
     else
     {
       ViewBag.Message="Error";
     }
  }
return View(model);
}

因此,当您运行应用程序时,将显示简单的Index()视图。

获取数据的索引视图

   using (Html.BeginForm("Index", "Home"))
    {
        <div class="row">
            <div class="col-md-6 col-sm-3">
            </div>
            <div class="col-md-6 col-sm-9">
                <div id="sample_6_filter" class="dataTables_filter">
                    <label>
                        @Html.TextBox("ID", ViewBag.ID == null ? "" : (string)ViewBag.ID, new { @class = "form-control input-inline", placeholder = "ID" })
                        <button class="btn green-haze" type="submit" id="submit">
                            <i class="fa fa-search"></i>
                        </button>
                    </label>
                </div>
            </div>
        </div>
    }
    @using (Html.BeginForm("Index", "Home", FormMethod.Post))
    {
        @Html.HiddenFor(x => x.ID)
        @Html.HiddenFor(x => x.CREATED_ON)
        <div class="form-horizontal">

            <div class="form-group">
                <label class="control-label col-sm-4">Name</label>
                <div class="col-sm-5">
                    @Html.TextBoxFor(a => a.Name, new { @class = "form-control", @maxlength = "50" })
                </div>
                <div class="col-sm-3 text-danger">

                </div>
            </div>
 <div class="form-group">
       <div class="col-sm-12 text-center">
                <button type="submit" name="command" value="createUser" class="btn btn-lg btn-green hvr-underline-from-center">Submit</button>
       </div>
  </div>
    }

您需要输入数据库的 ID 或任何 Uniq 字段才能在View中获得结果。 当您单击按钮时,将调用 [HttpGet] Index 方法并在视图中显示记录。

然后您可以修改数据。单击提交,它将用于
“ [HttPost]索引” 仍然按照上述代码和方法自动完成。

现在,您只需要在视图中设置数据即可。
希望你能理解!! 享受吧!