select A.CODPROD,A.DESCRICAO,A.DTMOVLOG DATA,A.NUMNOTA,ROUND(A.QT,2)QTDE,A.PUNIT,A.NOMECODOPER OPERACAO,ROUND(A.P_TOTAL,2)P_TOTAL,
(SELECT QTEST - PCEST.QTRESERV QTEST FROM PCEST WHERE CODFILIAL = 1 AND CODPROD = A.CODPROD)QTESTOQUE
FROM(
SELECT PCMOV.CODPROD,PCMOV.DESCRICAO,
       TRUNC(PCMOV.DTMOV) DTMOV, 
       PCMOV.DTMOVLOG, 
       PCMOV.NUMNOTA, 
       PCMOV.NUMSEQ, 
       PCMOV.NUMSEQPED, 
       PCMOV.NUMTRANSENT, 
       PCMOV.DTCANCEL, 
       DECODE(DTCANCEL,NULL,'','Cancelado') SITUACAO, 
       PCMOV.CODUSUR, 
       PCMOV.NUMTRANSVENDA, 
       PCMOV.NUMCAR, 
       PCMOV.NUMLOTE, 
       PCMOV.CODFISCAL, 
       NVL(PCMOV.CUSTOREAL,0) CUSTOREAL, 
       NVL(PCMOV.CUSTOFIN,0) CUSTOFIN, 
       (CASE 
         WHEN (SUBSTR(PCMOV.CODOPER,1,1) = 'E') THEN 
             NVL(PCMOV.CUSTOFIN,0) 
         ELSE NVL(PCMOV.CUSTOFINEST,0) 
       END) CUSTOFINEST, 
       NVL(PCMOV.CUSTOULTENT,0) CUSTOULTENT, 
       NVL(PCMOV.CUSTOFORNEC,0) CUSTOFORNEC, 
       NVL(PCMOV.CUSTOCONT,0) CUSTOCONT, 
       DECODE(PCMOV.CODOPER, 
              'E',PCMOV.CODFORNEC, 
              'EB',PCMOV.CODFORNEC, 
              'ET',PCMOV.CODFORNEC, 
              'ER',PCMOV.CODFORNEC, 
              'ES',PCMOV.CODFORNEC, 
              PCMOV.CODCLI) CODCLI, 
              NVL(PCMOV.CODFUNCLANC,0) AS CODFUNCLANC, 
           DECODE(SUBSTR(PCMOV.CODOPER, 1, 1), 
                  'S',(PCMOV.QT * (-1)), 
                  'R',(PCMOV.QT * (-1)), 
                  DECODE(NVL(PCMOVCOMPLE.QTRETORNOTV13, 0), 0, NVL(PCMOV.QT, 0), PCMOVCOMPLE.QTRETORNOTV13)) AS QT,   
              NVL(PCMOV.PUNIT,0) PUNIT, 
       PCMOV.CODOPER, 
       DECODE(PCMOV.CODOPER, 
              'E', DECODE(GREATEST(PCMOV.QT,0),0,'Entrada Cancelada','Entrada Merc.'), 
              'EB',DECODE(GREATEST(PCMOV.QT,0),0,'Bonif. Cancelada','Entrada Bonific.'), 
              'ET',DECODE(GREATEST(PCMOV.QT,0),0,'Entrada Transf. Cancelada','Entrada Transf.'), 
              'EA',DECODE(GREATEST(PCMOV.QT,0),0,'Entrada Ajuste Cancelada','Ajuste Estoque'), 
              'E1',DECODE(GREATEST(PCMOV.QT,0),0,'Entrada Avaria Cancelada','Entrada Avaria'), 
              'EI',DECODE(GREATEST(PCMOV.QT,0),0,'Ajuste Invent. Cancelado','Ajuste Invent.'), 
              'ED',DECODE(GREATEST(PCMOV.QT,0),0,'Devolução Cancelada','Dev. Cliente'), 
              'EN',DECODE(GREATEST(PCMOV.QT,0),0,'Dev. Venda Consig. Cancelada','Dev. Venda Consignada'), 
              'ER',DECODE(GREATEST(PCMOV.QT,0),0,'Simples Remessa Cancelada','Simples Remessa'), 
              'ES',DECODE(GREATEST(PCMOV.QT,0),0,'Sobra Mercadoria Cancelamento','Sobra de Mercadoria'), 
              'EM',DECODE(GREATEST(PCMOV.QT,0),0,'Ent. Mat. Consumo Cancelada','Entrada Materiais de Consumo'), 
              'EC',DECODE(GREATEST(PCMOV.QT,0),0,'Ent. Consig. Cancelada','Entrada Consignação'), 
              'EO',DECODE(GREATEST(PCMOV.QT,0),0,'Dev. Comodato Cancelada','Devolução de Comodato'), 
              'EX',DECODE(GREATEST(PCMOV.QT,0),0,'Dev. Avulsa Cancelada','Devolução Avulsa'), 
              'EG',DECODE(GREATEST(PCMOV.QT,0),0,'Entrada Benefic. Cancelada','Entrada de Beneficiamento'), 
              'S', DECODE(GREATEST(PCMOV.QT,0),0,'NF Cancelada','Saida'), 
              'SD',DECODE(GREATEST(PCMOV.QT,0),0,'Dev. Cancelada','Dev. Fornecedor'), 
              'SB',DECODE(GREATEST(PCMOV.QT,0),0,'Saida Bonific. Cancelada','Saida Bonific.'), 
              'ST',DECODE(GREATEST(PCMOV.QT,0),0,'Saida Transf. Cancelada','Saida Transf.'), 
              'S1',DECODE(GREATEST(PCMOV.QT,0),0,'Avaria Reaprov. Cancelada','Avaria por Reaproveitamento'), 
              'SS',DECODE(GREATEST(PCMOV.QT,0),0,'Saída Sobra Cancelada','Saída de Sobra'), 
              'SA',DECODE(GREATEST(PCMOV.QT,0),0,'Saída Ajuste Cancelada','Ajuste Estoque'), 
              'SI',DECODE(GREATEST(PCMOV.QT,0),0,'Ajuste Invent. Cancelado','Ajuste Invent.'), 
              'SR',DECODE(GREATEST(PCMOV.QT,0),0,'Simples Remessa Cancelada','Simples Remessa'), 
              'SC',DECODE(GREATEST(PCMOV.QT,0),0,'Saída Consig. Cancelada','Saída Consignação'), 
              'SO',DECODE(GREATEST(PCMOV.QT,0),0,'Remessa Comodato Cancelada','Remessa de Comodato'), 
              'SF',DECODE(GREATEST(PCMOV.QT,0),0,'Dev. Comodato Fornec. Cancelada','Devolução de Comodato a Fornecedor'), 
              'RA',DECODE(GREATEST(PCMOV.QT,0),0,'Req. Avulsa Cancelada','Requisição Avulsa'), 
              'EP',DECODE(GREATEST(PCMOV.QT,0),0,'Cancelamento Produção','Entrada Produção'), 
              'SP',DECODE(GREATEST(PCMOV.QT,0),0,'Cancelamento Produção','Requisição Mat.Prima'), 
              'SV',DECODE(GREATEST(PCMOV.QT,0),0,'Saída Avaria Cancelada','Saída por Avaria'), 
              'SM',DECODE(GREATEST(PCMOV.QT,0),0,'Saída Mat. Consumo Cancelada','Saída Materiais de Consumo'), 
              'SL',DECODE(GREATEST(PCMOV.QT,0),0,'Saída Perda Cancelada','Saída de Perda'), 
              'EL',DECODE(GREATEST(PCMOV.QT,0),0,'Ent. Perda Cancelada','Entrada de Perda'), 
              'EF',DECODE(GREATEST(PCMOV.QT,0),0,'Entrada Comodato Cancelada','Entrada de Comodato'), 
              'SN',DECODE(GREATEST(PCMOV.QT,0),0,'Saída Benefic. Cancelada','Saída de Beneficiamento'), 
              'EV',DECODE(GREATEST(PCMOV.QT,0),0,'Ent. Dev. Rem. Benefic. Cancelada','Entrada Devolução de Remessa para Beneficiamento'), 
              'EG',DECODE(GREATEST(PCMOV.QT,0),0,'Ent. Benefic. Cancelada','Entrada de Beneficiamento'), 
              'Desconhecido') NOMECODOPER, 
       (NVL(PCMOV.PUNIT,0)*DECODE(NVL(PCMOVCOMPLE.QTRETORNOTV13, 0), 0, NVL(PCMOV.QT, 0), PCMOVCOMPLE.QTRETORNOTV13)) P_TOTAL, 
       (CASE 
          WHEN PCMOV.CODOPER IN ('SA', 'EA') THEN 
            (SELECT DISTINCT HISTORICO 
               FROM PCLANC 
              WHERE NUMTRANSENT = PCMOV.NUMTRANSENT 
                AND ROWNUM = 1) 
          ELSE 
            ' ' 
       END) MOTIVO 
  FROM PCMOV, 
       PCPRODUT, 
       PCMOVCOMPLE 
 WHERE PCMOV.CODPROD IN(SELECT CODPROD FROM PCPRODUT WHERE CODSEC IN(10020))
   AND PCMOV.CODPROD = PCPRODUT.CODPROD 
   AND PCMOV.NUMTRANSITEM = PCMOVCOMPLE.NUMTRANSITEM(+) 
   AND NVL(PCMOVCOMPLE.MOVEST, 'S') = 'S' 
   AND PCMOV.DTMOV BETWEEN '01-JAN-2020' AND '29-SEP-2021'
   AND NVL(PCMOV.CODFILIALNF, PCMOV.CODFILIAL) = '1' 
   AND PCMOV.CODOPER <> 'S' 
   AND ((NVL(PCPRODUT.ESTOQUEPORLOTE, 'N') = 'S' AND 
        PCMOV.NUMLOTE IS NOT NULL) OR 
        (NVL(PCPRODUT.ESTOQUEPORLOTE, 'N') = 'N' AND 
        PCMOV.NUMLOTE IS NULL)) 
   AND PCMOV.STATUS IN ('B','AB') 
   AND NOT EXISTS (SELECT DISTINCT (PCNFSAID.NUMTRANSVENDA) 
                     FROM PCNFSAID, 
                          PCPRODUT 
                    WHERE PCNFSAID.NUMTRANSVENDA = PCMOV.NUMTRANSVENDA 
                      AND PCNFSAID.CODFILIAL = PCMOV.CODFILIAL 
                      AND PCMOV.CODOPER = 'S' 
                      AND PCNFSAID.CONDVENDA IN (4, 7, 14) 
                      AND PCMOV.CODPROD = PCPRODUT.CODPROD 
                      AND PCPRODUT.TIPOMERC = 'CB') 
    AND NOT (FERRAMENTAS.F_BUSCARPARAMETRO_ALFA('DEVOLVESIMPLESREMTV13TOTAL',PCMOV.CODFILIAL,'N') = 'S' 
 AND PCMOV.ROTINACAD LIKE '%1332%' AND NVL(PCMOVCOMPLE.QTRETORNOTV13,0) = 0) 
   AND NOT EXISTS (SELECT NUMNOTA FROM PCNFSAID WHERE NUMTRANSVENDA = PCMOV.NUMTRANSVENDA AND SITUACAONFE IN (110,205,301,302,303)) 
ORDER BY PCMOV.CODOPER, PCMOV.DTMOV, PCMOV.NUMNOTA
)A WHERE A.DTCANCEL IS NULL AND A.CODOPER = 'E' ORDER BY CODPROd,DATA
	Boa tarde. Estou com essa dúvida: 
	Preciso em um select trazer os dados com a seguinte condição:  
	Quando  o valor do punit repetir, somente traz o ultimo registro. ou seja a maior data. 
 
	caso contrário, traz todos os registros. 
 
	é possíveç, mais não sei como. Tentei usar o ROW_NUMBER(). Mas não encontrei uma forma de usar. 
 
	Greato