Jump to content
asacap1000

resultado em cada linha

Recommended Posts

Galera estou com uma consulta que ainda não consegui entender o porque. gostaria que ela trouxesse em apenas uma linha mas não vem de forma alguma.

 

SELECT BO.LAGER,
               BO.ID_OS,
               K.ID_KLIENT,
               K.SUCHBEGRIFF CNPJ_CPF,
               K.NAME,
               BI.DIV_1 LOTE,
               BI.DIV_10 DI_DDE,
               (SELECT DISTINCT DIS.ID_DISPATCHER
                  FROM FISCAL.DOCHD DC, WMS_EADI.DISPATCHER DIS
                 WHERE DC.DOCHD_DOC_ID = BO.NR_NF
                   AND DC.DOCHD_RPS_DESP = DIS.SUCHBEGRIFF) COD_COMISSARIA,
               (SELECT DISTINCT DIS.BEZ
                  FROM FISCAL.DOCHD DC, WMS_EADI.DISPATCHER DIS
                 WHERE DC.DOCHD_DOC_ID = BO.NR_NF
                   AND DC.DOCHD_RPS_DESP = DIS.SUCHBEGRIFF) COMISSARIA,
               BO.NR_NF,
               BO.DATE_BILL,
               BO.DATE_EMISS,
            --------ABAIXO OS TIPOS DE SERVIÇOS ONDE ESTÃO OCORRENDO CADA RESULTADO ELE CRIA UMA LINHA----------------   
               (SELECT SUM(ROUND(OSI.PREIS, 2))
                  FROM BILL_OS_ITEM OSI
                 WHERE OSI.LAGER = BO.LAGER
                   AND OSI.ID_KLIENT = K.ID_KLIENT
                   AND OSI.ID_OS = BO.ID_OS
                   AND OSI.BILLITE = BI.BILLITE
                   AND OSI.DIV_1 = BI.DIV_1
                      --AND NVL(OSI.DIV_10, 'x') = NVL(BI.DIV_10, 'x')
                   AND OSI.BILLITE IN
                       (SELECT BLL.BILLITE
                          FROM BILL_ITEM BLL, WERTE WER
                         WHERE BLL.TIPO_FAT = WER.WERT
                           AND WER.WERTE_BER = 'ITENSF'
                           AND WER.WERT = 'ARMAZ')) VLR_ARMAZ,
                           
                           
               (SELECT SUM(ROUND(OSI.PREIS, 2))
                  FROM BILL_OS_ITEM OSI
                 WHERE OSI.LAGER = BO.LAGER
                   AND OSI.ID_KLIENT = K.ID_KLIENT
                   AND OSI.ID_OS = BO.ID_OS
                   AND OSI.BILLITE = BI.BILLITE
                   AND OSI.DIV_1 = BI.DIV_1
                      --AND NVL(OSI.DIV_10, 'x') = NVL(BI.DIV_10, 'x')
                   AND OSI.BILLITE IN
                       (SELECT BLL.BILLITE
                          FROM BILL_ITEM BLL, WERTE WER
                         WHERE BLL.TIPO_FAT = WER.WERT
                           AND WER.WERTE_BER = 'ITENSF'
                           AND WER.WERT = 'GER.RISCO')) VLR_GER_RISCO,
                           
                           
               (SELECT SUM(ROUND(OSI.PREIS, 2))
                  FROM BILL_OS_ITEM OSI
                 WHERE OSI.LAGER = BO.LAGER
                   AND OSI.ID_KLIENT = K.ID_KLIENT
                   AND OSI.ID_OS = BO.ID_OS
                   AND OSI.BILLITE = BI.BILLITE
                   AND OSI.DIV_1 = BI.DIV_1
                      --AND NVL(OSI.DIV_10, 'x') = NVL(BI.DIV_10, 'x')
                   AND OSI.BILLITE IN
                       (SELECT BLL.BILLITE
                          FROM BILL_ITEM BLL, WERTE WER
                         WHERE BLL.TIPO_FAT = WER.WERT
                           AND WER.WERTE_BER = 'ITENSF'
                           AND WER.WERT = 'MOVIMENT')) VLR_MOVIMENTACAO,
                           
                           
               (SELECT SUM(ROUND(OSI.PREIS, 2))
                  FROM BILL_OS_ITEM OSI
                 WHERE OSI.LAGER = BO.LAGER
                   AND OSI.ID_KLIENT = K.ID_KLIENT
                   AND OSI.ID_OS = BO.ID_OS
                   AND OSI.BILLITE = BI.BILLITE
                   AND OSI.DIV_1 = BI.DIV_1
                      --AND NVL(OSI.DIV_10, 'x') = NVL(BI.DIV_10, 'x')
                   AND OSI.BILLITE IN
                       (SELECT BLL.BILLITE
                          FROM BILL_ITEM BLL, WERTE WER
                         WHERE BLL.TIPO_FAT = WER.WERT
                           AND WER.WERTE_BER = 'ITENSF'
                           AND WER.WERT = 'DESUNIT')) VLR_DESUNIT,
                           
                           
               (SELECT SUM(ROUND(OSI.PREIS, 2))
                  FROM BILL_OS_ITEM OSI
                 WHERE OSI.LAGER = BO.LAGER
                   AND OSI.ID_KLIENT = K.ID_KLIENT
                   AND OSI.ID_OS = BO.ID_OS
                   AND OSI.BILLITE = BI.BILLITE
                   AND OSI.DIV_1 = BI.DIV_1
                      --AND NVL(OSI.DIV_10, 'x') = NVL(BI.DIV_10, 'x')
                   AND OSI.BILLITE IN
                       (SELECT BLL.BILLITE
                          FROM BILL_ITEM BLL, WERTE WER
                         WHERE BLL.TIPO_FAT = WER.WERT
                           AND WER.WERTE_BER = 'ITENSF'
                           AND WER.WERT = 'PESAGEM')) VLR_PESAGEM,
                           
                           
               (SELECT SUM(ROUND(OSI.PREIS, 2))
                  FROM BILL_OS_ITEM OSI
                 WHERE OSI.LAGER = BO.LAGER
                   AND OSI.ID_KLIENT = K.ID_KLIENT
                   AND OSI.ID_OS = BO.ID_OS
                   AND OSI.BILLITE = BI.BILLITE
                   AND OSI.DIV_1 = BI.DIV_1
                      --AND NVL(OSI.DIV_10, 'x') = NVL(BI.DIV_10, 'x')
                   AND OSI.BILLITE IN
                       (SELECT BLL.BILLITE
                          FROM BILL_ITEM BLL, WERTE WER
                         WHERE BLL.TIPO_FAT = WER.WERT
                           AND WER.WERTE_BER = 'ITENSF'
                           AND WER.WERT LIKE 'AVERBA%')) VLR_AVERBACAO,
                           
                           
               (SELECT SUM(ROUND(OSI.PREIS, 2))
                  FROM BILL_OS_ITEM OSI
                 WHERE OSI.LAGER = BO.LAGER
                   AND OSI.ID_KLIENT = K.ID_KLIENT
                   AND OSI.ID_OS = BO.ID_OS
                   AND OSI.BILLITE = BI.BILLITE
                   AND OSI.BILLITE IN
                       (SELECT BLL.BILLITE
                          FROM BILL_ITEM BLL, WERTE WER
                         WHERE BLL.TIPO_FAT = WER.WERT
                           AND WER.WERTE_BER = 'ITENSF'
                           AND WER.WERT = 'FAT.MINIMO.')) VLR_FAT_MINIMO,
                           
                           
               (SELECT SUM(ROUND(OSI.PREIS, 2))
                  FROM BILL_OS_ITEM OSI
                 WHERE OSI.LAGER = BO.LAGER
                   AND OSI.ID_KLIENT = K.ID_KLIENT
                   AND OSI.ID_OS = BO.ID_OS
                   AND OSI.BILLITE = BI.BILLITE
                   AND OSI.DIV_1 = BI.DIV_1
                      --AND NVL(OSI.DIV_10, 'x') = NVL(BI.DIV_10, 'x')
                   AND OSI.BILLITE IN
                       (SELECT BLL.BILLITE
                          FROM BILL_ITEM BLL, WERTE WER
                         WHERE BLL.TIPO_FAT = WER.WERT
                           AND WER.WERTE_BER = 'ITENSF'
                           AND BLL.BILLITE NOT IN ('21.02', '21.03')
                           AND WER.WERT = 'OUT.SERV.')) VLR_OUTROS_SERV,
                           
                           
               (SELECT SUM(ROUND(OSI.PREIS, 2))
                  FROM BILL_OS_ITEM OSI
                 WHERE OSI.LAGER = BO.LAGER
                   AND OSI.ID_KLIENT = K.ID_KLIENT
                   AND OSI.ID_OS = BO.ID_OS
                   AND OSI.BILLITE = BI.BILLITE
                   AND OSI.DIV_1 = BI.DIV_1
                      --AND NVL(OSI.DIV_10, 'x') = NVL(BI.DIV_10, 'x')
                   AND OSI.BILLITE IN
                       (SELECT BLL.BILLITE
                          FROM BILL_ITEM BLL, WERTE WER
                         WHERE BLL.TIPO_FAT = WER.WERT
                           AND WER.WERTE_BER = 'ITENSF'
                           AND BLL.BILLITE = '21.02'
                           AND WER.WERT = 'OUT.SERV.')) TRANSF_IN,
                           
                           
               (SELECT SUM(ROUND(OSI.PREIS, 2))
                  FROM BILL_OS_ITEM OSI
                 WHERE OSI.LAGER = BO.LAGER
                   AND OSI.ID_KLIENT = K.ID_KLIENT
                   AND OSI.ID_OS = BO.ID_OS
                   AND OSI.BILLITE = BI.BILLITE
                   AND OSI.DIV_1 = BI.DIV_1
                      --AND NVL(OSI.DIV_10, 'x') = NVL(BI.DIV_10, 'x')
                   AND OSI.BILLITE IN
                       (SELECT BLL.BILLITE
                          FROM BILL_ITEM BLL, WERTE WER
                         WHERE BLL.TIPO_FAT = WER.WERT
                           AND WER.WERTE_BER = 'ITENSF'
                           AND BLL.BILLITE = '21.03'
                           AND WER.WERT = 'OUT.SERV.')) TRANSF_OUT
                           
                           
          FROM BILL_OS BO, BILL_OS_ITEM BI, KLIENTEN K
         WHERE BO.LAGER = BI.LAGER
           AND BO.ID_KLIENT = BI.ID_KLIENT
           AND BO.ID_OS = BI.ID_OS
           AND BO.LAGER = K.LAGER
           AND BO.ID_KLIENT = K.ID_KLIENT
           and k.id_klient = '3099'
           and BO.NR_NF = '121304'
           AND BO.STATUS = '90'
        AND TRUNC(BO.DATE_BILL) BETWEEN '28/08/2019' AND '28/08/2019'
         GROUP BY BO.LAGER,
                  BO.ID_OS,
                  K.ID_KLIENT,
                  K.SUCHBEGRIFF,
                  K.NAME,
                  BO.DATE_EMISS,
                  BO.NR_NF,
                  BO.DATE_BILL,
                  BI.BILLITE,
                  BI.DIV_1,
                  BI.DIV_10

image.thumb.png.29f19a5fe8c0bfd8f729fa044db4a1f6.png

 

Alguem consegue identificar neste select porque ele vem assim?

Share this post


Link to post
Share on other sites
10 horas atrás, Motta disse:

Os campos de seu sql não "batem" com a imagem.

 

 

é o mesmo sim é que não tinha colocado todso os campos segue dados antes.

 

image.png.d574e424faf3afdcdbf0d1b71480fa77.png

 

 

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 asacap1000
      Olá galera estou quebrando a cabeça aqui e não sei mais o que fazer. Estamos migrando nossa intranet que estava desatualizada demais e estamos colocando toda ela em php7.3.
      Dentro desse sistema temos varias consultas que são realizadas no Oracle. As consultas estão ocorrendo 100% mas ao chegar na plataforma de relatórios travou tudo. Não consegui acertar o meio de consultar por período, já utilizei "to_date, to_char, trunc" e nada. Interessante que no PLSQL o to_date funciona certo
      SELECT DISTINCT TO_DATE(IO.TIME_ARRIVAL)
        FROM IN_OUT IO
       WHERE TO_DATE(IO.TIME_ARRIVAL) BETWEEN '01/11/2021' AND '23/11/2021'
       
      1    04/11/2021
      2    18/11/2021
      3    17/11/2021
      4    14/11/2021
      5    22/11/2021
      6    08/11/2021
      7    11/11/2021
      8    13/11/2021
      9    09/11/2021
      10    10/11/2021
      11    05/11/2021
      12    19/11/2021
      13    15/11/2021
      14    03/11/2021
      15    06/11/2021
      16    23/11/2021
      17    01/11/2021
      18    02/11/2021
      19    16/11/2021
      20    20/11/2021
      21    12/11/2021
      22    21/11/2021
       
      Se eu utilizar ele ignora a data que estabeleci para a consulta
       TO_CHAR(IO.TIME_ARRIVAL,'DD/MM/YYYY') BETWEEN '01/11/2021' AND '23/11/2021'
       
      1    03/07/2013
      2    05/07/2013
      3    18/06/2013
      4    21/05/2013
      5    20/05/2013
      6    12/08/2013
      7    21/08/2013
      8    23/08/2013
      9    02/09/2013
      10    12/09/2013
       
      Isso no PLSQL, no caso do PHP o to_date não funciona nem gera o relatório, e no to_char funciona mas ignorando as datas apontadas.
       
      O que dá pra  fazer pra resolver isso, tenho que finalizar essa migração até final de Dezembro e estou começando a ficar preocupado com o tempo
       
      Agradeço qualquer ajuda que vier
    • By manolegal
      Boa tarde
      Tenho 5 campos do tipo select no meu formulário.  A seguir um dos campos.
      <div id="resp" class="form-group col-md-3" placeholder="Responsável" title="Pesquisar por Responsável"> <select class="form-control" id="resp" name="resp" placeholder="Responsável" title="Pesquisar por Responsável"> <option value="">Responsável</option> <?php $Sql = "SELECT ..."; $Resultado = ... while ($linha = @pg_fetch_array($Resultado)){. $id_responsavel_bd = $linha["id_responsavel"]; $nome_responsavel_bd = $linha["responsavel"]; if ($resp == $id_responsavel_bd){ echo "<option value='$id_responsavel_bd' selected = 'selected'>$nome_responsavel_bd</option>";} else{ echo "<option value='$id_responsavel_bd'>$nome_responsavel_bd</option>";} } ?> </select> </div> Tenho uma função jquery que ao selecionar qualquer um destes campos, faz uma requisição ajax para atualizar uma div do meu form.
      <script type="text/javascript"> $(document).ready(function(){ $('select').change(function(){ // Todos selects $('form').submit(function(){ var dados = $(this).serialize(); $.ajax({ type: "POST", url: 'arquivo_ajax.php', dataType: 'html', data: dados, }).done(function(data){ //console.log(data); $("#list").empty().html(data); }); return false; }); $("#meu_form").trigger('submit'); }); }); </script> Ao abrir o formulário e fazer a primeira seleção de algum campo do tipo select, é gerada uma solicitação ajax.
      O problema é que a cada nova seleção deste campo e de algum outro campo, ao invés de realizar UMA ÚNICA REQUISIÇÃO, está aumentando o número de requisições a cada nova ação.
      Como não tenho muitos conhecimentos em jquery/ajax em minha dúvida:
      - É normal ir aumentando o número de requisições?
      - Deveria sempre realizar apenas uma requisição (imagino que seja correto)?
      - Meu código está correto? Se não está, onde estou errando?
      Desde já agradeço pela colaboração.
       
       
    • By ldblucas
      Boa tarde,
       
      Atualmente qual a melhor formar de fazer um conexao C# com o banco Oracle ?
       
       
       
      desde já agradeço
    • By mr22robot
      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
×

Important Information

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