Ir para conteúdo
asacap1000

transformar resultado de um select de várias linhas para uma linha

Recommended Posts

Galera salve salve a todos,

 

Estou com um problema em um select  e preciso da ajuda de vocês.

 

O select se refere a calculo de faturamentos os quais calculam os itens cobrados na NF.

Eu preciso gerar um relatório destes lançamentos e com isso criei o select  abaixo.

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,
               (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 = 'AVERBAÇÃO')) 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 bo.status = '90'
           and k.id_klient = '2464'
        --and trunc(bo.date_bill) between '$inicio' and '$fim'
         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

Ele me traz os resultados por linhas de cada tipo de cobrança.

Segue imagem do resultado.

image.thumb.png.5548630874b10747847395f6f0768cb1.png

 

Eu preciso que os resultados viessem em apenas uma linha, estou quebrando a cabeça com isso.

o resultado tem que ser assim:

 

image.thumb.png.ee2d8248173fd8433404ec0c608e2df3.png

Compartilhar este post


Link para o post
Compartilhar em outros sites

Crie uma conta ou entre para comentar

Você precisar ser um membro para fazer um comentário

Criar uma conta

Crie uma nova conta em nossa comunidade. É fácil!

Crie uma nova conta

Entrar

Já tem uma conta? Faça o login.

Entrar Agora

  • Conteúdo Similar

    • Por sadamkim
      Pessoal,  me deparei com um problema.
      Tenho uma Tabela, onde fica armazenada as transações dos clientes.
      Cada transação tem vários registros com o campo STATUS.
       
      Preciso fazer um MAX, para pegar a ultima transação por data, e assim saber qual foi o status da mesma.
      Mas ao utilizar o MAX e selecionar o campo STATUS ele me traz todos os registro, porque o mesmo não pode agrupar por status, por conter valores diferentes.
      É possível criar alguma forma de selecionar no meu caso a ultima transação por data (MAX) e trazer o campo status?
      Seja com alguma procedure, ou outra função do ORACLE.


    • Por douglas.ribeiro.id
      Bom dia a todos
       
      a varios anos que nao tenho que criar um script no oracle nao consigo lembrar ne como começar e tambem estou sem o oracle instalado na maquina
      alguem poderia me ajudar? o problema e este: 
      Crie um segundo script (SCRIPT2.SQL) que possua um bloco de código para que gere registros fictícios para as tabelas criadas. Gere 1000 registros para a tabela EXAME_NF. Para cada EXAME_NF gere 3 registros. Faça com que a DATACADASTRO do EXAME_NF comece em 10 dias atrás, fazendo com que a cada 100 registros a data seja aumentada em 1 dia, distribuindo assim os 1000 registros em 10 dias diferentes de cadastro.
    • Por MateusDuarte
      Podem me ajudar? Sou novato em PHP e estou precisando de uma ajudinha.
      Tenho 2 tabelas no banco: filmes e generos.
      Faço o cadastro individual de todos os generos na tabela generos, e no cadastro de filmes eu puxo todos os generos por um multiple select. Até ai tudo certo, ele salva no banco de dados assim:
      genero1, genero2, genero3.
       
      Porém na hora de mostrar eu não sei separar eles das virgulas.
      Segue meu SELECT simples:
      <main class="content"> <?php $sql = "SELECT * FROM genero ORDER BY RAND()"; $result = $connect->query($sql); if($result->num_rows > 0) { while($row = $result->fetch_assoc()) { $teste = $row["id_genero"]; ?> <section class="panel"> <h2><a id="links-generos" href="generos-filmes.php?id=<?php echo $row['id_genero'];?>"><?php echo $row["descricao"];?></a></h2> <div class="recentslider"> <div class="swiper-container"> <div class="swiper-wrapper"> <?php $sql_t = "SELECT * FROM filmes WHERE id_genero = ".$teste." ORDER BY RAND()"; $result_t = $connect->query($sql_t); if($result_t->num_rows > 0) { while($row_t = $result_t->fetch_assoc()) { ?> <div class="swiper-slide"><?php echo "<a href='single-filmes.php?id=".$row_t['id_filme']."&genero=".$row_t['id_genero']."';>";?><img src="capa/<?php echo $row_t["capa_filme"];?>"><h3 class="hometitle"><?php echo $row_t["titulo_filme"];?></h3></a></div> <?php }} else { echo "0 results"; } ?> </div> <div class="nextdirection recent-next"><img src="img/right-arrow.svg"> </div> <div class="leftdirection recent-prev"><img src="img/left-arrow.svg"> </div> </div> </div> </section> <?php }} else { echo "0 results"; } ?> </main> (Desculpa se não ficou alinhado, só copiei e colei.)

      Reparem que primeiro dou um select na tabela genero, e salvo o ID dela em uma variavel, e depois vou um select na tabela filmes usando a variavel que salvei antes como uma condição.
      Porem na tabela filmes, os generos estão salvos separados por virgula. Como consigo fazer um select separando ela das virgulas?
       
    • Por Jonatas Provido
      Pessoal veja se consegue me ajudar 
      Hoje tenho uma  TABELA1 e TABELA2
      Tabela =  TABELA1
      Colunas = NCM
                         IPOS_FEDER
                         IPOS_MUNIC
                         IPOS_GLOBAL
                         IPOS_ESTAD
      A Tabela2 onde esta com as informações novas que precisa ser atualizado a Tabela1
      TABELA = TABELA2
      COLUNAS = NCM
                            FEDERAL
                            MUNICIP
                            GLOBAL
                            ESTADU
                       
      Preciso que compare o coluna NCM as demais coluna se diferente valor tabela 2 atualiza a tabela1 
       
      já li vários post porem acho que a forma que estou pesquisando não seja coerente. 
      Obrigado! pela atenção

       
×

Informação importante

Ao usar o fórum, você concorda com nossos Termos e condições.