首页 > Windows开发 > 详细

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

时间:2018-11-26 12:46:34      阅读:716      评论:0      收藏:0      [点我收藏+]

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

 

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

原文:https://www.cnblogs.com/douf/p/10019582.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!