如何解决Datable.Rows.Contains(value) 导致缺少主键异常
我正在尝试查看 DataTable 的一行是否包含一个值,但它显示“System.Data.MissingPrimaryKeyException: 'Table 没有主键。'”我不知道为什么会有一个键需要在一行中找到一个值,并且需要一些关于如何正确浏览行以找到值的指导。 我用注释标记了引发异常的 if 语句。
DataTable OutputDV = new DataTable();
DataView ScrumTeams = ISBL.GetScrumTeams();
//this dataview returns this: [CountDate,ScrumTeam,DefectCount]
DataView alldefects = ISBL.Getdefects(dtstartdate,dtenddate);
//Adding the columns for the datview
DataColumn ScrumTeamName = new DataColumn("ScrumTeam",typeof(string));
ScrumTeamName.ReadOnly = true;
OutputDV.Columns.Add(ScrumTeamName);
//first create columns of all dates
foreach (DaTarow x in alldefects.ToTable().Rows)
{
//if there isnt a column by name of x then add one
if (!OutputDV.Columns.Contains(x["CountDate"].ToString()))
{
OutputDV.Columns.Add(x["CountDate"].ToString());
}
//CODE BELOW CAUSES EXCEPTION:
//System.Data.MissingPrimaryKeyException: 'Table doesn't have a primary key.'
if (!OutputDV.Rows.Contains(x["ScrumTeam"].ToString()) || OutputDV.Rows.Count == 0)
{
OutputDV.Rows.Add(x["ScrumTeam"].ToString());
}
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。