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
那么这里到底是哪里有问题?是在没法查到资料