首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >编辑和删除复合主键问题

编辑和删除复合主键问题
EN

Stack Overflow用户
提问于 2014-05-10 23:52:38
回答 3查看 3.8K关注 0票数 1

这是我的编辑控制器:

代码语言:javascript
运行
复制
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);
}

在我看来,这就是我所说的:

代码语言:javascript
运行
复制
@Html.ActionLink("Modifier", "Edit", new {  id=d.TAUX_ID })

这是我的模型Taux

代码语言:javascript
运行
复制
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:传递的主键值的数量必须与实体上定义的主键值的数量相匹配。

所以我试着这么做:

代码语言:javascript
运行
复制
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的相同问题)?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2014-05-11 05:39:22

如果我能理解你的问题。这三个属性是您的键,但不是您的主键,正如我在代码中看到的,您刚才添加了注释,精确地说,CAT_IDC_GARANT是您的外键。关于第一次尝试。这意味着只有Taux_ID是您的主键。如果要使用扩展方法Find工作,则需要精确地确定表中属性Key的属性(该属性位于表中的主键)。在你的情况下,你可以:

编辑

代码语言:javascript
运行
复制
  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; }
   }

那么在你的行动中,不要改变:

代码语言:javascript
运行
复制
    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);
    }
票数 2
EN

Stack Overflow用户

发布于 2014-05-11 14:10:57

最简单的尝试就是改变

代码语言:javascript
运行
复制
public ActionResult Edit(int taux_id ,int c_garant, short cat_id)

转到

代码语言:javascript
运行
复制
public ActionResult Edit(int id ,int c_garant, short cat_id)

然后离开

代码语言:javascript
运行
复制
@Html.ActionLink("Modifier", "Edit", new {  id=d.TAUX_ID, c_garant=d.C_GARANT, cat_id=d.CAT_ID })

和现在一样

票数 1
EN

Stack Overflow用户

发布于 2014-05-11 01:14:29

ActionLink中传递的路由值需要匹配action方法中参数的名称。

将您的ActionLink更改为:

代码语言:javascript
运行
复制
@Html.ActionLink("Modifier", "Edit", new { taux_id=d.TAUX_ID, c_garant=d.C_GARANT, cat_id=d.CAT_ID })
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/23587537

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档