如何在不使用实体框架的情况下在MVC4中执行编辑功能?

时间:2015-01-20 06:37:02

标签: c# asp.net-mvc-4

我只想使用mvc4编辑旧数据。例如,城市名称需要从chennai更改 (从模型填充的下拉列表)到pune。有人可以指导我吗?

以下是我的代码:

控制器:

[HttpGet]
    public ActionResult display(Create model)
    {

        List<Create> city = new List<Create>();
        using (connectionstring pcs = new connectionstring())
        {
            city = pcs.grp.OrderBy(a => a.cityname).ToList();

        }
        ViewBag.cityname = new SelectList(city, "cityname", "cityname");
        return View(model);

    }

    [HttpPost, ActionName("display")]
    [ValidateAntiForgeryToken]
    public ActionResult display1( Create cg)
    {

        List<Create> city = new List<Create>();
        using (connectionstring pcs = new connectionstring())
        {
            city = pcs.grp.OrderBy(a => a.cityname).ToList();

        }
    ViewBag.cityname = new SelectList(city, "cityname", "cityname");

        if (ModelState.IsValid) 
        {


            string oldgcityname = cg.cityname.ToString().Trim();
    using (NpgsqlConnection conn = new NpgsqlConnection(ConfigurationManager.ConnectionStrings["portalconnectionstring"].ConnectionString))
            {

                       using( NpgsqlCommand cmd=new NpgsqlCommand("update tblcity set cityname='$1' where cityname='"+oldcityname+"'",conn))
            cmd.ExecuteNonQuery();



    }
         }

         return View(cg);
    }      

查看:

 @using (Html.BeginForm()) {
@Html.ValidationSummary(true)
@Html.AntiForgeryToken()

<table>
<tr> <td> 
    <div class="editor-label">
        @Html.Label("Select old cityname")
    </div> </td>
    <td>
    <div class="editor-field">
        @Html.DropDownListFor(model => model.cityname,@ViewBag.cityname as SelectList,"select")
        @Html.ValidationMessageFor(model => model.cityname)
    </div>

   </td></tr>
<tr> <td> 
    <div class="editor-label">
        @Html.Label("Enter new cityname")
    </div> </td>
    <td>
    <div class="editor-field">
        @Html.EditorFor(model => model.cityname)
        @Html.ValidationMessageFor(model => model.cityname)
    </div>

   </td></tr>
   <tr><td> 
    <p>
        <input type="submit" value="Create" />
    </p>
    </td></tr>

1 个答案:

答案 0 :(得分:1)

创建一个包含旧名称和新名称的属性的视图模型

查看模型

public class CreateVM
{
  [Display(Name = "Old name")]
  [Required]
  public string OldName { get; set; }
  [Display(Name = "New name")]
  [Required]
  public string NewName { get; set; }
  public SelectList CityList { get; set; }
}

控制器

[HttpGet]
public ActionResult Edit(CreateVM model)
{
  CreateVM model = new CreateVM();
  ...
  model.CityList = new SelectList(city, "cityname", "cityname");
  return View(model);
}

[HttpPost]
public ActionResult Edit(CreateVM model)
{
  // the model now contains the selected old name and its new name
}

查看

@model CreateVM
@using(Html.BeginForm())
{
  @Html.LabelFor(m => m.OldName)
  @Html.DropDownListFor(m => m.OldName, Model.CityList, "-Please select-")
  @Html.ValidationMessageFor(m => m.OldName)
  @Html.LabelFor(m => m.NewName)
  @Html.TextBoxFor(m => m.NewName)
  @Html.ValidationMessageFor(m => m.NewName)
  <input type="submit" />
}

正如Jon Skeet所说,使用参数化SQL!