C#判断DataTable1 A列的集合是否为DataTable2 B列的集合的子集

cs 复制代码
DataSet ds2 = (DataSet)res2.Anything;
// 检查  集合B是否为集合A的子集
var table1MaterialCodes = ds.Tables[2].AsEnumerable().Select(row => row["Code"]).ToList();  //DataSet1 表Code列集合A
var table2MaterialCodes = ds2.Tables[0].AsEnumerable().Select(row => row["MaterialCode"]).ToList(); //DataSet2 表MaterialCode列集合B
bool isSubset = table2MaterialCodes.All(code => table1MaterialCodes.Contains(code));   //判断集合B是否为集合A的子集

if (!isSubset)
{
var missingMaterialCodes = table2MaterialCodes.Where(code => !table1MaterialCodes.Contains(code)).ToList();
StringBuilder msg = new StringBuilder();
foreach (var code in missingMaterialCodes)
{
    // msg.Append(",");
    msg.Append(code);
    msg.Append("。");
}
    msg.Append("显示集合B不在集合A的数据");
    ShowMessage(msg.ToString(), false);
    return;
 }
}
  1. LINQ (Language Integrated Query): LINQ是.NET框架的一部分,它提供了一种查询各种数据源(如数组、集合、XML文档和数据库)的能力,就像查询SQL数据库一样。这里使用的是LINQ to Objects,即对内存中的对象集合进行查询。

  2. bool isSubset : 这是一个布尔变量,用于存储最终的判断结果。如果条件成立(即ds2.Tables[0]的所有materialcode都在ds0.Tables[2]中找到),则isSubsettrue;否则为false

  3. table2MaterialCodes.All(...) : All是LINQ中的一个扩展方法,适用于任何实现了IEnumerable<T>接口的类型。它接受一个谓词作为参数(在这个例子中是一个lambda表达式),并检查序列中的所有元素 是否都满足这个谓词。如果序列中的每个元素都使这个谓词返回true,那么All方法本身就返回true;如果序列中有任何一个元素使谓词返回falseAll方法就返回false

  4. code => table1MaterialCodes.Contains(code) : 这是传递给All方法的谓词,一个lambda表达式。对于table2MaterialCodes列表中的每一个materialcode值,这个表达式都会被求值。code是lambda表达式的参数,代表table2MaterialCodes列表中的当前元素。table1MaterialCodes.Contains(code)是lambda表达式的主体,它检查table1MaterialCodes列表是否包含code。如果包含,表达式返回true;否则返回false

综上所述,这行代码bool isSubset = table2MaterialCodes.All(code => table1MaterialCodes.Contains(code));的作用是:遍历ds2.Tables[0]中的每个materialcode,检查它是否在ds.Tables[0]code列表中。如果所有的materialcode都能在ds.Tables[2]中找到,那么isSubset将为true,表示ds2.Tables[0]中的materialcodeds.Tables[2]code的一个子集。如果有任何一个materialcodeds.Tables[2]中找不到,isSubset将为false

当判断出ds2.Tables[0]中的某些materialcodeds.Tables[2]中不存在时,我们使用LINQ的Where方法配合Contains方法来筛选出那些在ds.Tables[2]中不存在的materialcode。这是通过table2MaterialCodes.Where(code => !table1MaterialCodes.Contains(code)).ToList()这行代码完成的,它会生成一个列表missingMaterialCodes,包含了所有在ds.Tables[2]中找不到的materialcode

相关推荐
前端小张同学2 小时前
服务器部署 gitlab 占用空间太大怎么办,优化思路。
后端
databook2 小时前
Manim实现闪光轨迹特效
后端·python·动效
hj5914_前端新手3 小时前
javascript基础- 函数中 this 指向、call、apply、bind
前端·javascript
薛定谔的算法3 小时前
低代码编辑器项目设计与实现:以JSON为核心的数据驱动架构
前端·react.js·前端框架
Hilaku3 小时前
都2025年了,我们还有必要为了兼容性,去写那么多polyfill吗?
前端·javascript·css
武子康3 小时前
大数据-98 Spark 从 DStream 到 Structured Streaming:Spark 实时计算的演进
大数据·后端·spark
yangcode3 小时前
iOS 苹果内购 Storekit 2
前端
LuckySusu3 小时前
【js篇】JavaScript 原型修改 vs 重写:深入理解 constructor的指向问题
前端·javascript
LuckySusu3 小时前
【js篇】如何准确获取对象自身的属性?hasOwnProperty深度解析
前端·javascript
LuckySusu3 小时前
【js篇】深入理解 JavaScript 作用域与作用域链
前端·javascript