获取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,但所有帖子都与删除重复/发现重复有关,这并不能解决我的目的。
您可以使用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);
}