问题描述
- LINQ关于IEqualityComparer<T> 接口的问题
-
Linq的Distinct()方法不是说筛选数据内重复的数据吗?
原谅我只是刚学LINQ,也查阅了资料,但是我依然无法理解。
我按照书上看的,实现了一个IEqualityComparer 接口,如果真按照书上说的使用一个List的方式来做筛选的确是没问题。
于是突然想到,既然IEqualityComparer 接口是一个泛型,那么我传入一个DataRow也是可以的?
于是就写了代码
DataTable dt = new DataTable();
dt.Columns.Add("Index", typeof(int));DataRow row = dt.NewRow();
row["Index"] = "1";
dt.Rows.Add(row);DataRow row1 = dt.NewRow();
row1["Index"] = "2";
dt.Rows.Add(row1);DataRow row2 = dt.NewRow();
row2["Index"] = "2";
dt.Rows.Add(row2);RowIEqualityComparer rowEq = new RowIEqualityComparer();
var Query = dt.Rows.OfType().Distinct(rowEq);
foreach (DataRow item in Query)
{
Console.WriteLine(item["Index"].ToString());
}
Console.ReadLine();public class RowIEqualityComparer:IEqualityComparer
{
public bool Equals(DataRow row1,DataRow row2)
{
if (row1==null&&row2==null)
{
return true;
}
if (row1==null||row2==null)
{
return false;
}
if (row1["Index"].ToString()==row2["Index"].ToString())
{
return false;
}
return true;
}public int GetHashCode(DataRow row) { return row.GetHashCode(); } } 程序也没有报错,按照常规来理解,这样的代码最终执行的输出结果应该是 1 2 但是实际上缺输出了 1 2 2 那么这里到底是哪里有问题?是在没法查到资料
解决方案
其实用不着,最简单的是用GroupBy。
var Query = dt.Rows.OfType<DataRow>().GroupBy(x => x["Index"].ToString()).Select(x => x.First());
就可以了。