无法启用约束.一行或多行包含违反非空、唯一或外键约束的值.MyDataset.Tables[0].合并



当我尝试合并数据集中的表时,发生了此异常:-(无法启用约束。一行或多行包含违反非空、唯一或外键约束的值。

法典:

MyDataset.Tables[0].Merge(dt, false, MissingSchemaAction.Add);

我在Murat Yıldız评论中查看了这个问题,但没有一个答案适用于我的设置。我的代码在Merge方法上也失败了。在我的情况下起作用的是这个片段,取自这里:http://www.codeproject.com/Tips/405938/Debugging-DataSet-Constraint-Errors

try
{
    dataSet.Merge(anotherDataSet);
}
catch (ConstraintException)
{
    foreach (DataTable table in dataSet.Tables)
    {
        DataRow[] rowErrors = table.GetErrors();
        System.Diagnostics.Debug.WriteLine(table.TableName + " Errors:" + rowErrors.Length);
        for (int i = 0; i < rowErrors.Length; i++)
        {
            System.Diagnostics.Debug.WriteLine(rowErrors[i].RowError);
            foreach (DataColumn col in rowErrors[i].GetColumnsInError())
            {
                System.Diagnostics.Debug.WriteLine(col.ColumnName + ":" + rowErrors[i].GetColumnError(col));
            }
        }
    }
}

最新更新