LINQ 分组问题

lcaiyhh 2012-03-29 03:18:34
A表
AID Name
1 张三
2 李四

B表
BID Money AID
1 2 1
2 3 1
3 4 2


查询的结果

AID Name SumMoney Count
1 张三 5 2
2 李四 4 1

就是以AID分组,查询钱的总数,跟合计的数量
...全文
65 1 打赏 收藏 转发到动态 举报
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
q107770540 2012-03-29
  • 打赏
  • 举报
回复

--测试数据准备:
CREATE TABLE _A
(
AID int,
Name nvarchar(50)
)

CREATE TABLE _B
(
BID int,
Money int,
AID int
)

insert into _A SELECT 1,'zhangsan' union SELECT 2,'lisi'

insert into _B select 1,2,1 union
select 2,3,1 union
select 3,4,2







//LINQ语句:
void Main()
{
var query=from a in this._As
join b in this._Bs
on a.AID equals b.AID into g
select new
{
AID=a.AID,
Name=a.Name,
SumMoney=g.Sum(t=>t.Money),
Count=g.Count()
};
Console.WriteLine("AID\tName\tSumMoney\tCount");
query.ToList().ForEach(q=>Console.WriteLine("{0}\t{1}\t\t{2}\t{3}",q.AID,q.Name,q.SumMoney,q.Count));
}
/*
AID Name SumMoney Count
1 zhangsan 5 2
2 lisi 4 1
*/

62,267

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧