我使用List
对象来包含我的主表与其一对多关系的辅助表中的项目。主表的PK
用作辅助表上的FK
字段。
但是,当记录尝试保存时,我收到此错误
Violation of PRIMARY KEY constraint 'PK_ClearinghousePartners'. Cannot insert duplicate
key in object 'dbo.ClearinghousePartners'. The duplicate key value is (0)
主要表格模型
仅供参考 - 此表包含大量字段,因此我只显示List
public partial class AgentTransmission
{
.
.
public virtual List<ClearinghousePartners> ClearinghousePartners { get; set; }
}
辅助表格模型
public partial class ClearinghousePartners
{
public int Id { get; set; }
public string ClearingHouseName { get; set; }
public string TradingPartnerName { get; set; }
public Nullable<System.DateTime> StartDate { get; set; }
public int AgtTransId { get; set; } //FK field corresponds to 'Id' on AgentTransmission
public virtual AgentTransmission AgentTransmission { get; set; }
}
控制器
当模型发回到控制器以保存异常时会抛出代码的这个区域。这是AgentTransmission
对象是全新的并且需要添加到数据库的实例。 ClearinhousePartners
集合中的每个项目也是如此。
每个都是全新的ClearinghousePartners
项,没有Id
和AgtTransId
字段的值。我需要首先保存AgentTransmission
对象,以便可以创建Id
字段,然后将其插入AgtTransId
对象的ClearinghousePartners
字段中。
agenttransmission.LastChangeDate = DateTime.Now;
agenttransmission.LastChangeOperator = Security.GetUserName(User);
db.AgentTransmission.Add(agenttransmission);
db.SaveChanges(); //Exception thrown here
查看
<fieldset id="ClearinghousePartners">
<legend>Clearinghouse Partners</legend>
<center>
<table>
<thead>
<th>Clearinghouse Name</th>
<th>Trading Partner Name</th>
<th>Start Date</th>
</thead>
<tbody>
@for (int i = 0; i < Model.ClearinghousePartners.Count(); i++)
{
<tr align="center">
@Html.HiddenFor(model => model.ClearinghousePartners[i].Id)
@Html.HiddenFor(model => model.ClearinghousePartners[i].AgtTransId)
<td>@Html.TextBoxFor(model => model.ClearinghousePartners[i].ClearingHouseName, new { style = "width: 100px" })</td>
<td>@Html.TextBoxFor(model => model.ClearinghousePartners[i].TradingPartnerName, new { style = "width: 100px" })</td>
<td>@Html.TextBoxFor(model => model.ClearinghousePartners[i].StartDate, new { style = "width: 100px" })</td>
</tr>
}
</tbody>
</table>
</center>
</fieldset>
答案 0 :(得分:5)
重复键值为(0)
我猜你的表没有设置为自动将主键值填充为identity
属性。声明应如下所示:
ClearinghousePartners int primary key PK_ClearinghousePartners identity
答案 1 :(得分:2)
您需要为ClearinghousePartners.[PrimaryKey]
指定一个新的未使用值,或者将此列设置为自动生成的列(在sql server中称为Identity列 - 您使用了什么RDBMS?)