Как сопоставить составной ключ в функциональности CRUD
Мне нужно сопоставить на основе двух ключей (комп и часть).
@foreach (var item in Model) {
<tr>
<td>
@Html.DisplayFor(modelItem => item.comp)
</td>
<td>
@Html.DisplayFor(modelItem => item.part)
</td>
...........................
<td>
@Html.ActionLink("Edit", "Edit", new { id=item.comp }) |
@Html.ActionLink("Details", "Details", new { id = item.comp }) |
@Html.ActionLink("Delete", "Delete", new { id = item.comp })
</td>
</tr>
}
как использовать составной ключ на странице индекса, а также в контроллере.
public ActionResult Edit(int? id)
{
DataView record = db.RecordDataView.Find(id);
if (record == null)
{
return HttpNotFound();
}
return View(record);
}
Если у кого есть идея, пожалуйста, ответьте.
1 ответ
Решение
Метод find находит объекты по первичному ключу. Если у вас есть составной первичный ключ, передайте значения ключей в том порядке, в котором они определены в модели:
@Html.ActionLink("Edit", "Edit", new { comp = item.comp, part = item.part }) |
@Html.ActionLink("Details", "Details", new { comp = item.comp, part = item.part }) |
@Html.ActionLink("Delete", "Delete", new { comp = item.comp, part = item.part })
В контроллере получите оба значения:
public ActionResult Edit(int? comp, int? part)
{
DataView record = db.RecordDataView.Find(comp, part);
if (record == null)
{
return HttpNotFound();
}
return View(record);
}
Применив указанное выше предложение, я получил ошибку:
The parameters dictionary contains a null entry for parameter 'isdel' of non-nullable type 'System.Boolean' for method 'System.Web.Mvc.ActionResult Edit(System.Nullable`1[System.Int32], Boolean)' in Controller'. An optional parameter must be a reference type, a nullable type, or be declared as an optional parameter.
Но в соответствии с этим предложением я попытался изменить подпись действия Details на
public ActionResult Details(int eid,bool isdeleted) //same parameter name as in my Entity Model.
Функциональность CRUD с составными ключами теперь работает нормально.
Спасибо @Jelle Oosterbosch