获取c#中数据表中所有重复行的计数

本文关键字:数据表 获取 | 更新日期: 2023-09-27 18:10:01

我正在通过运行存储过程填充数据集,并且我正在从数据集填充数据表。

DataSet RawDataSet = DataAccessHelper.RunProcedure("storedprocedureName");
//this will just return the dataset by running the procedure
DataTable RankTable = RawDataSet.Tables[0];

Datatable有以下值:

Vicky   Login   6/24/2014
Vicky   Login   6/25/2014
Arun    Game    6/26/2014
Arun    Login   6/27/2014
Kumar   Login   6/28/2014
Kumar   Game    6/29/2014
Arun    Login   6/30/2014
Arun    Login   7/1/2014
Kumar   Game    7/2/2014
Vicky   Login   7/3/2014
Arun    Login   7/4/2014
Arun    Game    7/5/2014

我想解析这个dataTable并得到每个人做了多少次动作,即每行重复了多少次:

Vicky   Login  3
Arun    Game   2
Arun    Login  4
Kumar   Login  1
Kumar   Game   2

我是c#新手。这可以在SQL中使用count(*)来完成,但我需要使用c#来完成。如果有什么方法可以做到这一点,请告诉我。

我已经搜索了SO,但所有帖子都与删除重复/发现重复有关,这并不能解决我的目的。

获取c#中数据表中所有重复行的计数

您可以使用LINQ实现,如:

var query = RankTable.AsEnumerable()
                    .GroupBy(r => new { Name = r.Field<string>("Name"), Action = r.Field<string>("Action") })
                    .Select(grp => new
                    {
                        Name = grp.Key.Name,
                        Action = grp.Key.Action,
                        Count = grp.Count()
                    });

这里假定Name是第一列的列名,假定Action是第二列的名称,其中包含login, game等值。

你可能会看到LINQ to DataSet - MSDN

用于输出:

foreach (var item in query)
{
    Console.WriteLine("Name: {0}, Action: {1}, Count: {2}",item.Name, item.Action,item.Count);
}