转自: 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;