由Linq和Transact Sql分组

时间:2016-03-18 12:37:08

标签: c# linq tsql

我有这个SQL查询

select GrupoEmpaque,NumIdConceptoEmpaque,sum(NumCantidadEmpaques) 
    from Movimientos_Pedidos 
    where StrIdDocumento = '009000PV00000000000000599' and (GrupoEmpaque is null or GrupoEmpaque = 0 )
    group by GrupoEmpaque , NumIdConceptoEmpaque  

**It Returns:** 

NULL    338 25

另一方面我有这个Linq,Pedido已经只有' 009000PV00000000000000599'数据

var EmpaquesItemUnico = Pedido.Movimientos_Pedidos
    .GroupBy(x => x.NumIdConceptoEmpaque)
    .Select(x => new { GrupoEmpaque = x.FirstOrDefault().GrupoEmpaque, TipoEmpaque = x.FirstOrDefault().Merlin_ConceptosFacturacionEmpaque, Cantidad = x.Sum(y => y.NumCantidadEmpaques) })
    .Where(x => x.GrupoEmpaque == 0 || x.GrupoEmpaque == null);

But now the results are       
NULL    338 28

现在我的问题是:

为什么TSQL返回25而Linq返回28? 如何使这些句子返回相同的结果?

1 个答案:

答案 0 :(得分:3)

您必须先在投影前过滤结果,并且t-sql和linq的两个groupby语句都不相同:

var EmpaquesItemUnico = Pedido.Movimientos_Pedidos
    .GroupBy(x => new
                  { 
                    NumIdConceptoEmpaque =x.NumIdConceptoEmpaque,
                    GrupoEmpaque  = x.GrupoEmpaque 
                  }
            )
    .Where(x => x.Key.GrupoEmpaque == 0 || x.Key.GrupoEmpaque == null)
    // now project here
    .Select(x=> new 
                   {
                    NumIdConceptoEmpaque  = x.Key.NumIdConceptoEmpaque,
                    GrupoEmpaque  = x.Key.GrupoEmpaque,
                    Sum = x.Sum(y => y.NumCantidadEmpaques)
                   });