C#匹配两个DataTable的某两列相同的值
时间: 2023-07-12 08:32:51 浏览: 120
你可以使用 LINQ 查询来匹配两个 DataTable 的某两列相同的值。以下是示例代码:
```csharp
var results = from table1 in dataTable1.AsEnumerable()
join table2 in dataTable2.AsEnumerable()
on table1.Field<int>("Column1") equals table2.Field<int>("Column2")
select new
{
Column1Value = table1.Field<int>("Column1"),
Column2Value = table2.Field<int>("Column2")
};
```
这个代码块将返回一个匿名类型的集合,其中包含两个 DataTable 中匹配的行的值。请将 "Column1" 和 "Column2" 替换为你要匹配的列的名称。
相关问题
C#比较两个DataTable表某列的差异
要比较两个 DataTable 表中某列的差异,可以使用 LINQ 查询和 `Except()` 方法来实现。
假设我们要比较两个 DataTable 表 `table1` 和 `table2` 中的某一列 `columnName` 的差异,可以按照以下步骤进行:
1. 使用 `AsEnumerable()` 方法将 DataTable 转换为 `IEnumerable<DataRow>`,以便在 LINQ 查询中使用。
2. 使用 `Select()` 方法选择需要比较的列。
3. 使用 `Except()` 方法获取两个表中不同的行。
下面是示例代码:
```csharp
// 获取 table1 和 table2 中不同的行
var diff = table1.AsEnumerable()
.Select(row => row.Field<string>(columnName))
.Except(table2.AsEnumerable()
.Select(row => row.Field<string>(columnName)));
// 输出差异
foreach (var val in diff)
{
Console.WriteLine(val);
}
```
上面的代码首先使用 `Select()` 方法选择了 `columnName` 列,并使用 `AsEnumerable()` 方法将 DataTable 转换为 `IEnumerable<DataRow>`。然后使用 `Except()` 方法获取两个表中不同的行,最后输出差异。
需要注意的是,如果两个表中包含相同的值但顺序不同,那么这些值将被视为不同,因此你可能需要使用 `OrderBy()` 方法来排序。例如:
```csharp
// 获取 table1 和 table2 中不同的行
var diff = table1.AsEnumerable()
.Select(row => row.Field<string>(columnName))
.OrderBy(val => val)
.Except(table2.AsEnumerable()
.Select(row => row.Field<string>(columnName))
.OrderBy(val => val));
// 输出差异
foreach (var val in diff)
{
Console.WriteLine(val);
}
```
这里使用 `OrderBy()` 方法对两个表的选择结果进行排序,以便获取准确的差异。
C#比较两个DataTable表某列的差异详细代码
以下是比较两个DataTable表某列的差异的详细代码:
```csharp
// 假设有两个 DataTable 对象 dt1 和 dt2,它们都有名为 "Column1" 的列
// 获取 dt1 中的 "Column1" 列
var dt1Column1 = dt1.AsEnumerable().Select(r => r.Field<string>("Column1")).ToList();
// 获取 dt2 中的 "Column1" 列
var dt2Column1 = dt2.AsEnumerable().Select(r => r.Field<string>("Column1")).ToList();
// 获取 dt1 中有但是 dt2 中没有的值
var dt1NotInDt2 = dt1Column1.Except(dt2Column1).ToList();
// 获取 dt2 中有但是 dt1 中没有的值
var dt2NotInDt1 = dt2Column1.Except(dt1Column1).ToList();
// 输出结果
Console.WriteLine("dt1 中有但是 dt2 中没有的值:");
foreach (var value in dt1NotInDt2)
{
Console.WriteLine(value);
}
Console.WriteLine("dt2 中有但是 dt1 中没有的值:");
foreach (var value in dt2NotInDt1)
{
Console.WriteLine(value);
}
```
以上代码中,首先使用 `AsEnumerable` 方法将 DataTable 对象转换为 `IEnumerable<DataRow>` 对象,然后使用 LINQ 查询语句获取指定列的值,并将结果转换为 List 对象。接着使用 `Except` 方法获取两个 List 对象中不同的值,最后输出结果。