火焰猫麟 2016-03-22 12:36 采纳率: 0%
浏览 2285
已采纳

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条回答 默认 最新

  • threenewbee 2016-03-22 15:23
    关注
     其实用不着,最简单的是用GroupBy。
    var Query = dt.Rows.OfType<DataRow>().GroupBy(x => x["Index"].ToString()).Select(x => x.First());
    就可以了。
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 FPGA-SRIO初始化失败
  • ¥15 MapReduce实现倒排索引失败
  • ¥15 ZABBIX6.0L连接数据库报错,如何解决?(操作系统-centos)
  • ¥15 找一位技术过硬的游戏pj程序员
  • ¥15 matlab生成电测深三层曲线模型代码
  • ¥50 随机森林与房贷信用风险模型
  • ¥50 buildozer打包kivy app失败
  • ¥30 在vs2022里运行python代码
  • ¥15 不同尺寸货物如何寻找合适的包装箱型谱
  • ¥15 求解 yolo算法问题