QDataSet – 如何比较两个数据集内容的差异

QDataSet 提供了两个函数来比较两个数据集的差异,并将结果保存到第三个数据集。

两个函数,其中 Intersect 函数用于取两个数据集中的交集部分,而 Diff 函数用于取两个数据集中不一样的部分。这两个函数的 AFields 用于记录要比较的字段列表,多个字段之间以 “,” 或 “;” 分隔,如果两个数据集中要比较的字段的名称不一致,则使用:

ASource1中的字段名=ASource2中的字段名

这种方式来建立两者之间的映射关系,如果两个字段名不一致,则会取第一个结果集中的字段名为最终结果集的字段名。

在使用这两个函数时,还要注意一点:这两个要比较数据集中对应的字段的类型要保持一致,否则比较无意义,程序会抛出异常。

Intersect 用于计算两个数据集中共同的记录,而 Diff 用于计算两个结果集中不同的记录,但额外提供了两个参数:

  • AIncSource1 为 True 时,将 ASource1 中有,而 ASource2 中无的记录加到结果中
  • AIncSource2 为 True 时,将 ASoruce2 中有,而 ASource1 中无的记录加到结果中

至于它们的调用方法,So easy!

程序实际运行效果截图,CC_1~CC_10 是两者公共的内容。DSDiff

分享到:

2 条评论

沙发空缺中,还不快抢~