我有以下sql,我想将其转换为linq

SELECT Contrato.finca, SUM(Pago.Importe_subtotal)
FROM Pago, Contrato
WHERE Pago.Contrato = Contrato.ID AND Pago.pagado = 1
GROUP BY Contrato.finca
ORDER BY 2 DESC
GO


我现在在linq中有以下内容,但是group by不起作用。

var x = from contrato in ctx.Contratos
        join pago in ctx.Pagos
        on contrato.ID equals pago.Contrato
        where pago.pagado == true
        group contrato by contrato.finca
        select contrato.Finca1;

最佳答案

认为这应该工作:

ctx.Pagos.Where(m=>m.pagado==true).GroupBy(m=>m.Contrato.finca)
    .Select(m=> new { Id= m.Key, Val= m.Sum(n => n.Importe_subtotal)})

关于c# - 使用join,group-by和where将sql转换为linq,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/14128357/

10-09 00:56