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