错误:无法在用于分组的表达式中使用聚合或子查询

时间:2013-11-06 18:35:12

标签: sql sql-server sql-server-2008

我收到此错误:无法在GROUP BY子句列表中使用的表达式中使用聚合或子查询。

我在互联网上搜索,但我不知道如何在我的情况下应用更正。我发现了不同类型的查询。

我正在尝试在字段中获取Count结果(第5行),但是当我添加Count查询时,我收到此错误。

我正在使用SQL SERVER 2008 R2。

当我从SELECT和GROUP BY中删除Count时,查询运行正确。

SELECT TF.COD_FORNECEDOR AS 'Cód. Fornec.',
    TF.NOM_FANTASIA AS 'Fornecedor',
    DM.COD_CONTRATO_RELACIONADO AS 'CONTRATO',
    UA2.NOM_USUARIO AS 'NOM_USUARIO_COMPRADOR',
    (SELECT COUNT(COD_CONTRATO_RELACIONADO) FROM TB_DEMANDA D INNER JOIN TB_PROCESSO P ON D.COD_CONTRATO_RELACIONADO = P.NUM_CONTRATO WHERE D.COD_CONTRATO_RELACIONADO = DM.COD_CONTRATO_RELACIONADO) AS 'NUM_ADITIVO',
    0 AS 'Qtd. Aditivo',
    SUM(DM.VAL_TOTAL_ORCADO) AS 'Valor Inicial',
    SUM(TP.VAL_CONTRATADO) AS 'Valor Final',
    ((SUM(TP.VAL_CONTRATADO) / SUM(DM.VAL_TOTAL_ORCADO)) -1) * 100 AS 'Var. %'
FROM TB_FORNECEDOR TF 
    LEFT JOIN TB_DEMANDA DM ON DM.COD_FORNECEDOR = TF.COD_FORNECEDOR
    LEFT JOIN TB_PROCESSO TP ON DM.COD_DEMANDA = TP.COD_DEMANDA
    LEFT JOIN TB_PROCESSO_FORNECEDOR PF ON PF.COD_PROCESSO = TP.COD_PROCESSO
    LEFT JOIN USUARIO UA ON UA.NUM_USUARIO = DM.NUM_USUARIO_COMPRADOR
    LEFT JOIN USUARIO UA2 ON UA2.NUM_USUARIO = DM.NUM_USUARIO_COMPRADOR
    LEFT JOIN TB_STATUS_DEMANDA_DATA SD ON SD.COD_DEMANDA = DM.COD_DEMANDA
    LEFT JOIN TB_BASELINE BA ON BA.COD_PROCESSO = TP.COD_PROCESSO
    LEFT JOIN TB_BASELINE_TAREFAS BT ON BT.COD_BASELINE = BA.COD_BASELINE AND BT.COD_PROCESSO = BA.COD_PROCESSO
    LEFT JOIN TB_STATUS_PROCESSO SP ON SP.COD_STATUS = SD.COD_STATUS
    LEFT JOIN TB_MEDIO_STATUS MS ON MS.COD_MEDIO_STATUS = SP.COD_MEDIO_STATUS
    left JOIN #TB_PROCESSO TT ON TT.COD_PROCESSO = TP.COD_PROCESSO
GROUP BY 
    TF.COD_FORNECEDOR,
    TF.NOM_FANTASIA,
    DM.COD_CONTRATO_RELACIONADO,
    UA2.NOM_USUARIO,
    (SELECT COUNT(COD_CONTRATO_RELACIONADO) FROM TB_DEMANDA D INNER JOIN TB_PROCESSO P ON D.COD_CONTRATO_RELACIONADO = P.NUM_CONTRATO WHERE D.COD_CONTRATO_RELACIONADO = DM.COD_CONTRATO_RELACIONADO)
ORDER BY TF.NOM_FANTASIA 

1 个答案:

答案 0 :(得分:3)

试试这个:

SELECT TF.COD_FORNECEDOR AS 'Cód. Fornec.',
    TF.NOM_FANTASIA AS 'Fornecedor',
    DM.COD_CONTRATO_RELACIONADO AS 'CONTRATO',
    UA2.NOM_USUARIO AS 'NOM_USUARIO_COMPRADOR',
    sq.cnt AS 'NUM_ADITIVO',
    0 AS 'Qtd. Aditivo',
    SUM(DM.VAL_TOTAL_ORCADO) AS 'Valor Inicial',
    SUM(TP.VAL_CONTRATADO) AS 'Valor Final',
    ((SUM(TP.VAL_CONTRATADO) / SUM(DM.VAL_TOTAL_ORCADO)) -1) * 100 AS 'Var. %'
FROM TB_FORNECEDOR TF 
    LEFT JOIN TB_DEMANDA DM ON DM.COD_FORNECEDOR = TF.COD_FORNECEDOR
    LEFT JOIN TB_PROCESSO TP ON DM.COD_DEMANDA = TP.COD_DEMANDA
    LEFT JOIN TB_PROCESSO_FORNECEDOR PF ON PF.COD_PROCESSO = TP.COD_PROCESSO
    LEFT JOIN USUARIO UA ON UA.NUM_USUARIO = DM.NUM_USUARIO_COMPRADOR
    LEFT JOIN USUARIO UA2 ON UA2.NUM_USUARIO = DM.NUM_USUARIO_COMPRADOR
    LEFT JOIN TB_STATUS_DEMANDA_DATA SD ON SD.COD_DEMANDA = DM.COD_DEMANDA
    LEFT JOIN TB_BASELINE BA ON BA.COD_PROCESSO = TP.COD_PROCESSO
    LEFT JOIN TB_BASELINE_TAREFAS BT ON BT.COD_BASELINE = BA.COD_BASELINE AND BT.COD_PROCESSO = BA.COD_PROCESSO
    LEFT JOIN TB_STATUS_PROCESSO SP ON SP.COD_STATUS = SD.COD_STATUS
    LEFT JOIN TB_MEDIO_STATUS MS ON MS.COD_MEDIO_STATUS = SP.COD_MEDIO_STATUS
    LEFT JOIN #TB_PROCESSO TT ON TT.COD_PROCESSO = TP.COD_PROCESSO
    LEFT JOIN (
                SELECT D.COD_CONTRATO_RELACIONADO, COUNT(COD_CONTRATO_RELACIONADO) AS cnt 
                FROM TB_DEMANDA D 
                        INNER JOIN TB_PROCESSO P ON D.COD_CONTRATO_RELACIONADO = P.NUM_CONTRATO 
                GROUP BY D.COD_CONTRATO_RELACIONADO
            ) sq ON sq.COD_CONTRATO_RELACIONADO = DM.COD_CONTRATO_RELACIONADO
GROUP BY 
    TF.COD_FORNECEDOR,
    TF.NOM_FANTASIA,
    DM.COD_CONTRATO_RELACIONADO,
    UA2.NOM_USUARIO,
    sq.cnt
ORDER BY TF.NOM_FANTASIA 

我将num_aditivo子查询集成到LEFT JOIN中。