zoukankan      html  css  js  c++  java
  • C# 两个datatable中的数据快速比较返回交集或差集

    最基本的写法无非是写多层foreach循环,数据量多了,循环的次数是乘积增长的。

    这里推荐使用Except()差集、Intersect()交集,具体性能没有进行对比。

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

    //与免打扰中的用户进行比较,筛选出可以正常接收推送的用户
    var normalReceive = dtUser.AsEnumerable().Except(dtDND.AsEnumerable(), DataRowComparer.Default);

    //比对两个表的用户名一致的,保存username到list中
    var intersectUser = dtUserPower.AsEnumerable().Intersect(normalReceive, DataRowComparer.Default);


      
    foreach (var item in intersectUser)
    {
    listTemp.Add(item["username"].ToString());
    }

    如果两个datatable中有部分字段相同,也就是说有可进行比对的字段的话。

    //与免打扰中的用户进行比较,筛选出可以正常接收推送的用户
    var normalReceive = from r in dtUser.AsEnumerable()
    where
    !(from rr in dtDND.AsEnumerable() select rr.Field<string>("username")).Contains(
    r.Field<string>("username"))
    select r;

    //比对两个表的用户名一致的,保存token到list中
    var intersectUser = from r in normalReceive.AsEnumerable()
    where
    (from rr in dtUserPower.AsEnumerable() select rr.Field<string>("username")).Contains(
    r.Field<string>("username"))
    select r;

    foreach (var item in intersectUser)
    {
    listTemp.Add(item["token"].ToString());
    }

  • 相关阅读:
    JS函数的定义与调用方法
    一次完整的浏览器请求流程
    【前端安全】JavaScript防http劫持与XSS
    深入理解display属性
    前端开发人员需要了解的CSS原理
    第 10 章 文件系统及实现
    第 9 章 虚拟内存管理
    第 8 章 内存管理策略
    第 7 章 死锁
    第 6 章 同步
  • 原文地址:https://www.cnblogs.com/lacey/p/5893380.html
Copyright © 2011-2022 走看看