C# 两个datatable中的数据快速比较返回交集或差集

Posted 豆腐配酱油

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C# 两个datatable中的数据快速比较返回交集或差集相关的知识,希望对你有一定的参考价值。

转自: https://www.cnblogs.com/lacey/p/5893380.html

如果两个datatable的字段完全一致的话,可以直接使用Except,Intersect

//Except()差集
var tempExcept = dt1.AsEnumerable().Except(dt2.AsEnumerable(), DataRowComparer.Default);

//Intersect()交集
var tempIntersect= dt1.AsEnumerable().Intersect(dt2.AsEnumerable(), DataRowComparer.Default);

 

如果两个datatable中有部分字段相同,可以使用Contains比较  

//差集
var tempExcept = from r in dt1.AsEnumerable()
where
!(from rr in dt2.AsEnumerable() select rr.Field<string>("username")).Contains(
r.Field<string>("username"))
select r;

//交集
var tempIntersect = from r in dt1.AsEnumerable()
where
(from rr in dt2.AsEnumerable() select rr.Field<string>("字段")).Contains(
r.Field<string>("字段"))
select r;

 

以上是关于C# 两个datatable中的数据快速比较返回交集或差集的主要内容,如果未能解决你的问题,请参考以下文章

您如何正确快速地比较 Datarows / Datatables?

C# 遍历datatable 比较textbox中的值,,是不是重复

C# 获取两个DataTable 的交集并集差集

如何在c#中动态组合两个或多个DataTables

如何比较两个 DataTable 并返回差异?

如何更改 DataTable C# 中的列格式