Jump to content
GustavoJacob15

Sql triplicando resultado

Recommended Posts

Quando eu executo esse fonte, trás o resultado triplicado

 

 

 

SELECT CN9_NUMERO  AS 'CONTRATO',
       CONVERT(DATE, SUBSTRING(CN9_DTINIC, 1, 4) + '-' + SUBSTRING(CN9_DTINIC, 5, 2) + '-' + SUBSTRING(CN9_DTINIC, 7, 2)) AS 'DT INICIO', 
       CONVERT(DATE, SUBSTRING(CN9_DTFIM, 1, 4) + '-' + SUBSTRING(CN9_DTFIM, 5, 2) + '-' + SUBSTRING(CN9_DTFIM, 7, 2)) AS 'DT FIM', 
       CN9_NUMERO  AS 'CENTRO DE CUSTO',
       CN9_ZZEMTI AS 'ART EMITIDA',
       CONVERT(DATE,CN9_ZZDTVA) AS 'VALIDADE DA ART',
       CN9_VLATU   AS 'VALOR CONTRATO',
       CNC_CLIENT AS 'CLIENTE',
       CNC_LOJACL AS 'LOJA CLIENTE',
       A1_NOME    AS 'NOME CLIENTE',
       CNE_PEDIDO AS 'PEDIDO',
       CNE_PERC   AS 'PERCENTUAL',
       C6_NOTA AS 'NOTA FISCAL',
       E1_NUM AS 'NUMERO',
       CNE_REVISA, 
       CONVERT(DATE,E1_BAIXA) AS 'DT BAIXA',
       CNF_VLPREV AS 'VALOR PREVISTO',
       CNF_PARCEL AS 'PARCELA',
       CONVERT(DATE,CNF_DTVENC) AS 'VENCIMENTO'
FROM CN9010 CN9
INNER JOIN CNC010 CNC ON CNC.CNC_NUMERO = CN9.CN9_NUMERO AND CNC.D_E_L_E_T_ =''
INNER JOIN SA1010 A1 ON CNC.CNC_CLIENT = A1.A1_COD AND CNC.CNC_LOJACL = A1.A1_LOJA AND A1.D_E_L_E_T_ =''
INNER JOIN CNF010 CNF ON CNF.CNF_CONTRA = CN9.CN9_NUMERO AND CN9.D_E_L_E_T_=''
INNER JOIN CNE010 CNE ON CNE.CNE_CONTRA = CNF.CNF_CONTRA AND CNE.D_E_L_E_T_=''
INNER JOIN SC6010 C6 ON C6.C6_NUM = CNE.CNE_PEDIDO AND C6.D_E_L_E_T_ =''
INNER JOIN SE1010 E1 ON E1.E1_NUM = C6.C6_NOTA AND E1.D_E_L_E_T_ ='' AND E1.E1_TIPO ='NF'
WHERE CN9.D_E_L_E_T_=''
AND CN9_NUMERO = '201000272'
AND CN9_REVISA = '002'
AND CN9.D_E_L_E_T_=''
AND CNF_CONTRA =  '201000272'
AND CNF_REVISA =  '002'
AND CNF.D_E_L_E_T_=''
AND CNE_CONTRA = '201000272'    
AND CNE_REVISA = '002'  
AND CNE.D_E_L_E_T_=''
AND E1_PREFIXO = 'SRV'
AND CNC_NUMERO = '201000272'
AND CNC_REVISA = '002'
  
GROUP BY CN9_NUMERO,CN9_REVISA,CN9_DTINIC,CN9_DTFIM,CN9_NUMERO,CN9_ZZEMTI,CN9_ZZDTVA,CN9_VLATU,CNC_CLIENT,CNC_LOJACL, A1_NOME, CNE_PEDIDO, CNE_PERC, C6_NOTA, E1_NUM, CNE_REVISA, E1_BAIXA, CNF_VLPREV, CNF_PARCEL, CNF_DTVENC

 

Share this post


Link to post
Share on other sites

1 verifique se os joins estão com todos os campos , não teria de ter o xxx_FILIAL ?

2 alguns dos joins ainda que certos tem uma relação de 1:n o que vai gerar um produto cartesiano indevido , tente um DISTINCT ou GROUP BY

 

estas tabela são do TOTVS não conheço todas para validar os joins

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now

  • Similar Content

    • By gersonab
      Boa tarde a todos, tenho um sistema de upload de arquivos que funciona perfeitamente, agora eu gostaria que estes arquivos fossem armazenados em nuvem, não no servidor, poderiam indicar um tutorial ou como proceder.
    • By Diego-SLP
      Bom dia,
       
      Teria como eu fazer um UPDATE na minha base colocando através de um FORM o VALOR_UNITARIO sendo que a QUANTIDADE já tenho na base de dados, e assim, atualizar o campo VALOR FINAL já? 
       
      Vou atualizar varios registros de uma vez.
    • By k9studio
      Olá Pessoal,
       
      Tenho um campo em uma tabela que grava os dados neste formato a baixo:
      {""user_id":"1","user_token":"5181e24c8a7e60304156e08595f48ad6"}
       
      como faço para chamar esses dados no php separados...
       
      fico grato se alguém puder ajudar..
    • By adrianno
      Boa noite, tenho a seguinte questão, tenho uma tabela com  campo  "valor"  que guarda um valor monetário e campo "data" com a data do lançamento e um campo "tipo" marcando se é entrada ou saida,  ao cadastrar um valor, coloco a data e qual tipo "entrada" ou "saida"    quero montar uma view que soma todos os valores por mês, separados por tipo, se é entrada ou saida.   A seguinte query me tras a soma, porém não agrupa pelo MES/ANO
      SELECT DATE_FORMAT(data, "%m/%Y") as MES, (select Sum(valor) from controle WHERE tipo = 'SAIDA' ) as VS, // soma tudo que for SAIDA (select Sum(valor) from controle WHERE tipo = 'ENTRADA' ) as VE // soma tudo que for ENTRADA FROM controle GROUP BY YEAR(data), MONTH(data) // agrupa por ANO/MES mas este grupo nao opera nas somas dos valores ORDER BY data DESC  Esta query  somas os valores  mas não filtra pelo mes/ano e tras a soma total de tudo ignorando o mes,  mostra o mesmo valor total de cada tipo em todos os meses:
      EXEMPLO DO RESULTADO
      MES                 VS(saida)     VE(entrada)
      06/2020         4600,00        9750,00
      05/2020         4600,00        9750,00
      04/2020         4600,00        9750,00
       
      Na prática cada mês deveria retornar as somas dos valores apenas dele. Como fazer com que  GROUP BY YEAR(data), MONTH(data)   tenha efeito correto em cada tipo?   
×

Important Information

Ao usar o fórum, você concorda com nossos Terms of Use.