首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >计算列表父实体的子实体的总和

计算列表父实体的子实体的总和
EN

Stack Overflow用户
提问于 2015-07-03 14:31:24
回答 3查看 1.6K关注 0票数 3

我必须计算有子服务的服务的总费用。在linq中计算实体总和的方法是:

代码语言:javascript
运行
复制
double totalcost = db.Services.Sum(s=>s.cost);

但是我如何计算列表服务的总费用,例如:

代码语言:javascript
运行
复制
double totalfee=db.services.childservices.sum(s=>s.fee);

或者类似的东西?我不想使用循环,因为当我必须一次计算1000个服务时,这需要很长的时间!

EN

回答 3

Stack Overflow用户

发布于 2015-07-03 14:44:26

我认为您的模型类似于以下内容:

代码语言:javascript
运行
复制
public class Service
{
  public long Id { get; set; }
  public double Cost { get; set; }
  public ICollection<ChildService> ChildServices { get; set; }
}

public class ChildService
{
  public long Id { get; set; }
  public double Fee { get; set; }
}

然后,您可以执行此操作来计算所有服务的总费用:

代码语言:javascript
运行
复制
double? totalFee = db.Services.Sum(service => service.ChildServices.Sum(child => (double?)child.Fee));

当数据库中没有要求和的数据时,double?会防止出现这种情况。在这种情况下,结果将是null

如果您想要所有服务的总费用列表,您可以:

代码语言:javascript
运行
复制
List<double?> totalFees = db.Services.Select(service => service.ChildServices.Sum(child => (double?)child.Fee)).ToList();

如果您想要0而不是null,只需将上述查询替换为:

代码语言:javascript
运行
复制
double totalFee = db.Services.Sum(service => service.ChildServices.Sum(child => (double?)child.Fee)) ?? 0;
List<double> totalFees = db.Services.Select(service => service.ChildServices.Sum(child => (double?)child.Fee) ?? 0).ToList();
票数 2
EN

Stack Overflow用户

发布于 2015-07-03 14:57:13

代码语言:javascript
运行
复制
var total = services.SelectMany(q => q.ChildServices).Distinct().Sum(p => p.Fee);
票数 0
EN

Stack Overflow用户

发布于 2015-07-03 15:07:19

代码语言:javascript
运行
复制
var childFeeSum=from parentService in db.Services select new { Fee=parentService.Sum(parent=>parent.ChildServices.Sum(f=>f.Fee))};
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/31200040

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档