gpt4 book ai didi

c# - DataRowComparer Except 长行比较失败

转载 作者:行者123 更新时间:2023-11-30 18:38:11 30 4
gpt4 key购买 nike

晚上好

我正在构建一种比较两个数据表(最后读取的数据表和我需要写入的数据表)并仅检索修改过的行的缓存。我使用 DataRowComparer.Default 作为 Equality Comparer,但它有错误的目标来比较具有许多字段的行。

它与具有短文本值的 3 列表完美配合,但比较长文本描述时,即使我更改单个字符,它也无法返回整个表。

代码很简单:

var diffDs = ds.Tables[0].AsEnumerable().Except(cachedTable.AsEnumerable(), DataRowComparer.Default);

想法?谢谢!

更新:手动调试我能够比较 ds.Tables[0].AsEnumerable() 行与 cachedtable.AsEnumerable() 行:绝对相等但与 DataRowComparer 不同。我已经删除了任何试图避免格式差异但没有成功的 DateTime 列。交叉口也不起作用。

更新 2:Except 不适用于空/空字段。对于 IEqualityComparer,它们似乎有所不同。

最佳答案

我找到了一个解决方案:

DataRowComparer 代码是这样工作的:

internal static bool AreEqual(object a, object b)
{
if (Object.ReferenceEquals(a, b))
{ // same reference or (null, null) or (DBNull.Value, DBNull.Value)
return true;
}
if (Object.ReferenceEquals(a, null) || Object.ReferenceEquals(a, DBNull.Value) ||
Object.ReferenceEquals(b, null) || Object.ReferenceEquals(b, DBNull.Value))
{ // (null, non-null) or (null, DBNull.Value) or vice versa
return false;
}
return (a.Equals(b) || (a.GetType().IsArray && CompareArray((Array)a, b as Array)));
}

如您所见,空值和 DBNull 的处理方式不同,null==DBNull 始终为 false。显然空字符串看起来像空字段,但它不是 DBNull。因此,由于这个空值,两个表面上相似的表是不同的。我的解决方案在从 xml 源(这是具有空字符串和空值的源)构建时解析 ds.Tables[0],并使用 System.Convert.DBNull 进行替换

现在比较完美了。

附言如果您从 sql 查询或从 xml 源构建数据表,则\n 和\r\n 也不同。假设上面的 null/DBNull 解决方案很容易解决。

关于c# - DataRowComparer Except 长行比较失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11829083/

30 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com