这是我的编辑控制器:
public ActionResult Edit(short id)
{
TAUX taux = db.TAUX.Find(id);
if (taux == null)
{
return HttpNotFound();
}
ViewBag.CAT_ID = new SelectList(db.CATEGORIE, "CAT_ID", "LIBELLE", taux.CAT_ID);
ViewBag.C_GARANT = new SelectList(db.GARANTIE, "C_GARANT", "LIB_ABREGE", taux.C_GARANT);
return PartialView("_Edit",taux);
}在我看来,这就是我所说的:
@Html.ActionLink("Modifier", "Edit", new { id=d.TAUX_ID })这是我的模型Taux:
public partial class TAUX
{
// the first 3 attributes are my primary key
public short CAT_ID { get; set; } // foreign key
public int C_GARANT { get; set; } // foreign key
public int TAUX_ID { get; set; }
[Required(ErrorMessage = "Taux est obligatoire")]
public decimal POURC_TAUX { get; set; }
public System.DateTime DATE_EFFET { get; set; }
public virtual CATEGORIE CATEGORIE { get; set; }
public virtual GARANTIE GARANTIE { get; set; }
}我所犯的错误是:
system.ArgumentException:传递的主键值的数量必须与实体上定义的主键值的数量相匹配。
所以我试着这么做:
public ActionResult Edit(int taux_id ,int c_garant, short cat_id)
{
TAUX taux = db.TAUX.Find(taux_id, c_garant, cat_id);
... }
//////////
@Html.ActionLink("Modifier", "Edit", new { id=d.TAUX_ID, c_garant=d.C_GARANT, cat_id=d.CAT_ID })但我有个问题:
参数字典包含非空类型'taux_id‘的参数'System.Int32’的空项,用于“pfebs0.Controllers.Taux contains”中的方法'System.Web.Mvc.ActionResult Edit(Int32,Int32,Int16)‘。可选参数必须是引用类型、可空类型,或者声明为可选参数。
如何解决(deleteAction的相同问题)?
发布于 2014-05-11 05:39:22
如果我能理解你的问题。这三个属性是您的键,但不是您的主键,正如我在代码中看到的,您刚才添加了注释,精确地说,CAT_ID和C_GARANT是您的外键。关于第一次尝试。这意味着只有Taux_ID是您的主键。如果要使用扩展方法Find工作,则需要精确地确定表中属性Key的属性(该属性位于表中的主键)。在你的情况下,你可以:
编辑
public partial class TAUX
{
public int TAUX_ID { get; set; }
[Required(ErrorMessage = "Taux est obligatoire")]
public decimal POURC_TAUX { get; set; }
public System.DateTime DATE_EFFET { get; set; }
public short CAT_ID { get; set; } // foreign key
public virtual CATEGORIE CATEGORIE { get; set; }
public int C_GARANT { get; set; } // foreign key
public virtual GARANTIE GARANTIE { get; set; }
}那么在你的行动中,不要改变:
public ActionResult Edit(int id=0, int cat_Id =0,short c_garant=0)
{
TAUX taux = db.TAUX.Where(p=>p.TAUX_Id==id &&p.CAT_ID==cat_Id && p.C_GARANT==c_garant).FirstOrDefault();
if (taux == null)
{
return HttpNotFound();
}
ViewBag.CAT_ID = new SelectList(db.CATEGORIE, "CAT_ID", "LIBELLE", taux.CAT_ID);
ViewBag.C_GARANT = new SelectList(db.GARANTIE, "C_GARANT", "LIB_ABREGE", taux.C_GARANT);
return PartialView("_Edit",taux);
}发布于 2014-05-11 14:10:57
最简单的尝试就是改变
public ActionResult Edit(int taux_id ,int c_garant, short cat_id)转到
public ActionResult Edit(int id ,int c_garant, short cat_id)然后离开
@Html.ActionLink("Modifier", "Edit", new { id=d.TAUX_ID, c_garant=d.C_GARANT, cat_id=d.CAT_ID })和现在一样
发布于 2014-05-11 01:14:29
在ActionLink中传递的路由值需要匹配action方法中参数的名称。
将您的ActionLink更改为:
@Html.ActionLink("Modifier", "Edit", new { taux_id=d.TAUX_ID, c_garant=d.C_GARANT, cat_id=d.CAT_ID })https://stackoverflow.com/questions/23587537
复制相似问题