火焰猫麟
2016-03-22 12:36
采纳率: 50%
浏览 2.3k
已采纳

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
    那么这里到底是哪里有问题?是在没法查到资料
  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

1条回答 默认 最新

  • blownewbee 2016-03-22 15:23
    已采纳
     其实用不着,最简单的是用GroupBy。
    var Query = dt.Rows.OfType<DataRow>().GroupBy(x => x["Index"].ToString()).Select(x => x.First());
    就可以了。
    
    点赞 打赏 评论

相关推荐 更多相似问题