首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >具有相同商品id的商品价格总和

具有相同商品id的商品价格总和
EN

Stack Overflow用户
提问于 2015-04-20 00:06:03
回答 1查看 148关注 0票数 0

我想在数据库表中具有相同项目id的所有行中的所有项目价格的总和。我的意思是,结果应该是一个数字,当我从下拉列表中选择一个特定的项目id时,它会自动放在文本框中。

我如何在linq中做到这一点?

代码语言:javascript
复制
public double oIlstGetVouchersDetailjh(int nvoucherID)
{
    Training_sNairoukhEntities1 sNairoukhEntities1 = new Training_sNairoukhEntities1();
    double sum = (from Entity in sNairoukhEntities1.INV_InventoryItems
                                where Entity.ItemID == nvoucherID
                                select Entity.ItemPrice).sum();
    return sum;
}

代码语言:javascript
复制
public double oIlstGetVouchersDetailjh(int nvoucherID)
{
    Training_sNairoukhEntities1 sNairoukhEntities1 = new Training_sNairoukhEntities1();
    double olstInvoicesSrech = from Entity in sNairoukhEntities1.INV_InventoryItems
    group Entity by Entity.ItemID == nvoucherID into g
    select g.sum(Entity => Entity.ItemPrice);

    return olstInvoicesSrech;
}

但是第二个查询告诉我这个消息不能隐式地将类型'System.Linq.IQueryable‘转换为'double

EN

回答 1

Stack Overflow用户

发布于 2015-04-20 01:39:59

在您的情况下,这将是可行的:

代码语言:javascript
复制
    Training_sNairoukhEntities1 sNairoukhEntities1 = new Training_sNairoukhEntities1();
    double sum = (from Entity in sNairoukhEntities1.INV_InventoryItems
                                where Entity.ItemID == nvoucherID
                                select Entity.ItemPrice).Sum(); // Change sum to Sum
    return sum;

这里有一个更简单的方法:

代码语言:javascript
复制
sNairoukhEntities1.INV_InventoryItems.Where(item => item.ItemID == nvoucherID).Sum(item => item.ItemPrice);
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/29732278

复制
相关文章

相似问题

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