Linq.js 求和里面哪里
Linq.js Sum inside Where
有什么方法可以用 SUM 在 Linq.JS 中过滤吗?
我的尝试:
var query = Enumerable
.From(self.data())
.Where("$$.Sum($.percent) > 100")
.ToArray();
错误:
linq.js: Uncaught TypeError: $$.Sum is not a function
这是我使用并解决的代码:
self.validatePercentualSumOfItens = () => {
const sumOfGroupedItens = Enumerable
.From(self.dadosCobranca().configuracoes())
.Where("$.idAgrupadorRateio != null && $.idAgrupadorRateio != -1")
.GroupBy("{ idAgrupadorRegra: $.idAgrupadorRegra,
idAgrupadorRateio: $.idAgrupadorRateio
}",
"parseFloat($.percentualRateio)",
"{ idAgrupadorRegra: $.idAgrupadorRegra,
idAgrupadorRateio: $.idAgrupadorRateio,
total: parseFloat($$.Sum()).toFixed(2)
}",
"$.idAgrupadorRegra + '-' + $.idAgrupadorRateio")
.ToArray();
const itensThatNotMatchAHundred = Enumerable
.From(sumOfGroupedItens)
.Where("$.total < 100 || $.total > 100")
.ToArray();
return itensThatNotMatchAHundred.length;
};
有什么方法可以用 SUM 在 Linq.JS 中过滤吗?
我的尝试:
var query = Enumerable
.From(self.data())
.Where("$$.Sum($.percent) > 100")
.ToArray();
错误:
linq.js: Uncaught TypeError: $$.Sum is not a function
这是我使用并解决的代码:
self.validatePercentualSumOfItens = () => {
const sumOfGroupedItens = Enumerable
.From(self.dadosCobranca().configuracoes())
.Where("$.idAgrupadorRateio != null && $.idAgrupadorRateio != -1")
.GroupBy("{ idAgrupadorRegra: $.idAgrupadorRegra,
idAgrupadorRateio: $.idAgrupadorRateio
}",
"parseFloat($.percentualRateio)",
"{ idAgrupadorRegra: $.idAgrupadorRegra,
idAgrupadorRateio: $.idAgrupadorRateio,
total: parseFloat($$.Sum()).toFixed(2)
}",
"$.idAgrupadorRegra + '-' + $.idAgrupadorRateio")
.ToArray();
const itensThatNotMatchAHundred = Enumerable
.From(sumOfGroupedItens)
.Where("$.total < 100 || $.total > 100")
.ToArray();
return itensThatNotMatchAHundred.length;
};