1. 程式人生 > >C# 兩個datatable中的資料快速比較返回交集或差集

C# 兩個datatable中的資料快速比較返回交集或差集

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

如果兩個datatable的欄位完全一致的話,可以直接使用Except,Intersect

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

//Intersect()交集
var tempIntersect= dt1.AsEnumerable().Except(dt12.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 tempExcept = from r in dt1.AsEnumerable()
where
(from rr in dt2.AsEnumerable() select rr.Field<string>("username")).Contains(
r.Field<string>("username"))
select r;