Ir para conteúdo

POWERED BY:

Arquivado

Este tópico foi arquivado e está fechado para novas respostas.

ghlevin

Fazendo união e agrupamento de duas consultas SQL

Recommended Posts

Tenho duas consultas SQL, que vão numa base do Oracle mas funcionam pelo SQL Server:

 

Consulta 1

SELECT IDHOTEL AS idhotel, RAZAOSOCIAL AS razaosocial, NOSSONUMERO AS nossonumero,
		NUMERODOCUMENTO AS numerodocumento, CAST(VALOR AS NUMERIC(15,2)) AS valor, END1 AS end1, END2 AS end2,
		replace(convert(NVARCHAR, DATAEMISSAO, 103), '-', '/') AS dataemissao, replace(convert(NVARCHAR, DATAPROGRAMADA, 103), '-', '/') AS datavencimento,
		HISTORICOCOMPL AS historico, NUMEROBOLETO AS numeroboleto, NUMLEITOR AS numleitor, (SUBSTRING(CODCONTA,1,4)+'/'+SUBSTRING(CODCONTA,5,5)+'-'+SUBSTRING(CODCONTA,10,2)) AS codconta, NOSSONUMERO AS nossonumero, STATUS AS status FROM OPENQUERY
		(CM_ORACLE,'SELECT DISTINCT D.IDHOTEL AS IDHOTEL, P.RAZAOSOCIAL AS RazaoSocial, (E.LOGRADOURO || '', '' || E.NUMERO || '' - '' || E.COMPLEMENTO) AS END1, (E.BAIRRO || '' - '' || SUBSTR(E.CEP,1,5) || ''-'' || SUBSTR(E.CEP,6,3) || '' - '' || C.NOME || ''/'' || C.UF ) AS END2,
		P.NOME AS Nome,  D.DATAPROGRAMADA AS DataProgramada,
   		ROUND(L.VALOR,2) AS Valor, L.HISTORICOCOMPL AS HistoricoCompl, D.NODOCUMENTO || ''        '' || D.COMPLDOCUMENTO AS NumeroDocumento, D.NUMDIGCODBARRAS AS NumeroBoleto, D.NUMLEITCODBARRAS AS NumLeitor,
   		D.DATAEMISSAO AS DataEmissao, D.DATAVENCTO AS DataVencimento, PT.NUMEMPRESABANCO AS CodConta, L.DATALANCTO AS DataLancamento, D.NOSSONUMERO AS NossoNumero,
   		S.SALDO AS Saldo, (CASE D.STATUS WHEN ''1'' THEN ''PENDENTE'' ELSE ''PAGO'' END) AS Status, D.CODDOCUMENTO AS CodDocumento, D.NUMFATURA AS NumeroFatura FROM
   		DOCUMENTO D, PESSOA P, LANCTODOCUM L, ENDPESS E, CIDADES C, PORTADORFORMA PT, ( SELECT (0) AS CODDOCUMENTO, (0.00) AS SALDO FROM DUAL ) S, TIPODOCRECPAG WHERE 
   		( D.IDFORCLI = P.IDPESSOA ) AND ( P.IDPESSOA = E.IDPESSOA ) AND ( E.IDCIDADES = C.IDCIDADES ) AND ( D.CODDOCUMENTO = L.CODDOCUMENTO ) AND ( D.OPERACAO = L.OPERACAO ) AND ( D.CODPORTFORMA = PT.CODPORTFORMA(+) ) AND
   		( ((RTRIM(L.HISTORICOCOMPL) <> ''ESTORNO'') OR (L.HISTORICOCOMPL IS NULL)) ) AND ( TIPODOCRECPAG.CODTIPDOC=D.CODTIPDOC ) AND  ( D.RECPAG = ''R'' ) AND
   		( EXISTS (SELECT CODTIPDOC FROM TIPODOCRECPAG A WHERE A.RECPAG    = ''R'' AND A.CODTIPDOC = TIPODOCRECPAG.CODTIPDOC AND NOT EXISTS ( SELECT 1 FROM USUARIOXTPDOCTO B
   		WHERE RECPAG = ''R'' AND B.IDUSUARIO = 80664974) UNION SELECT CODTIPDOC FROM TIPODOCRECPAG A WHERE A.RECPAG = ''R''
   		AND A.CODTIPDOC = TIPODOCRECPAG.CODTIPDOC AND EXISTS (SELECT 1 FROM USUARIOXTPDOCTO B
   		WHERE RECPAG = ''R'' AND A.CODTIPDOC = B.CODTIPDOC AND B.IDUSUARIO = 80664974) ) ) AND
   		(D.DATAPROGRAMADA > TO_DATE(''01/01/2015'', ''dd/mm/yyyy''))
   		ORDER BY RazaoSocial ASC') WHERE IDHOTEL = 239 AND NOSSONUMERO <> '' AND DATAPROGRAMADA
		BETWEEN (cast(2015 as varchar(4))  + '-' + cast(07 as varchar(2))  + '-' + cast(01 as varchar(2))) 
		AND (cast(2015 as varchar(4)) + '-' + cast(07 as varchar(2)) + '-' + cast(31 as varchar(2))) AND (HISTORICOCOMPL LIKE '%capital%' OR HISTORICOCOMPL LIKE '%giro%' OR HISTORICOCOMPL LIKE '%pré%') 

Consulta 2

SELECT IDHOTEL,RazaoSocial,CAST(TotalPago AS NUMERIC(15,2)) AS TotalPago,CAST(TotalPendente AS NUMERIC(15,2)) AS TotalPendente
FROM OPENQUERY (CM_ORACLE,'SELECT DISTINCT
   D.IDHOTEL,
   P.RAZAOSOCIAL AS RazaoSocial,
   SUM(ROUND((CASE D.STATUS WHEN ''1'' THEN L.VALOR ELSE 0 END),2)) AS TotalPendente,
   SUM(ROUND((CASE D.STATUS WHEN ''1'' THEN 0 ELSE L.VALOR END),2)) AS TotalPago
FROM
   DOCUMENTO D,
   PESSOA P,
   LANCTODOCUM L,
   ENDPESS E,
   CIDADES C,
   PORTADORFORMA PT,
   ( SELECT (0) AS CODDOCUMENTO, (0.00) AS SALDO FROM DUAL ) S,
   TIPODOCRECPAG
WHERE 
   ( D.IDFORCLI = P.IDPESSOA ) AND
   ( P.IDPESSOA = E.IDPESSOA ) AND
   ( E.IDCIDADES = C.IDCIDADES ) AND
   ( D.CODDOCUMENTO = L.CODDOCUMENTO ) AND
   ( D.OPERACAO = L.OPERACAO ) AND
   ( D.CODPORTFORMA = PT.CODPORTFORMA(+) ) AND
   ( ((RTRIM(L.HISTORICOCOMPL) <> ''ESTORNO'') OR (L.HISTORICOCOMPL IS NULL)) ) AND
   ( TIPODOCRECPAG.CODTIPDOC=D.CODTIPDOC ) AND
   ( D.RECPAG = ''R'' ) AND
   ( EXISTS (SELECT CODTIPDOC FROM TIPODOCRECPAG A WHERE A.RECPAG    = ''R''
   AND A.CODTIPDOC = TIPODOCRECPAG.CODTIPDOC AND NOT EXISTS ( SELECT 1 FROM USUARIOXTPDOCTO B
   WHERE RECPAG = ''R'' AND B.IDUSUARIO = 80664974) UNION
   SELECT CODTIPDOC FROM TIPODOCRECPAG A WHERE A.RECPAG = ''R''
   AND A.CODTIPDOC = TIPODOCRECPAG.CODTIPDOC AND EXISTS (SELECT 1 FROM USUARIOXTPDOCTO B
   WHERE RECPAG = ''R'' AND A.CODTIPDOC = B.CODTIPDOC AND B.IDUSUARIO = 80664974) ) ) AND
   (D.NOSSONUMERO <> ''NULL'') AND
   (D.DATAPROGRAMADA >= TO_DATE(''01/01/2014'', ''dd/mm/yyyy''))
   GROUP BY D.IDHOTEL,RazaoSocial
   ORDER BY RazaoSocial ASC') WHERE IDHOTEL = 239

Eu queria poder agrupar os dados das duas consultas pelos campos IDHotel e RazãoSocial, que existem em ambas.

É possível fazer isso? Tentei com UNION, mas aí ele me dá sempre duas linhas diferentes.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Não sei se entendi mas que posso haver um union a quantidade , tipo e ordem dos campos deve ser a mesma , na primeira se tem um "nosso_numero" na segunda um "valorpendente" , as queries parecem heterogeneas.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Descobri como fazer. É só usar JOIN e separar as consultas como tabelas.

Daí só fazer a seleção dos campos das tabelas e igualar T1.idhotel = T2.idhotel, por exemplo.

 

Podem fechar o tópico.

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • Por ILR master
      Boa tarde, pessoal.
      Espero que todos estejam bem.
       
      Seguinte:
      Tenho a seguinte consulta:
       
      $usuarios= "SELECT * FROM usuarios";
      $query= mysqli_query($conexao, $usuarios) or die ("Usuário não encontrado");
      $usuario = mysqli_fetch_array($query);
       
      Quero pegar apenas o campo 'nome' da tabela 'usuarios' e colocar todos os resultados da seguinte forma:
       
      $nomes = array("Rafael", "João", "Maria", "Pedro", "Patricia", "Camila");
       
      Agradeço desde já.
      Abs
       
       
    • Por FabianoSouza
      Tenho uma function que precisa receber 02 argumentos.
      Ela funciona se eu aplicar num select qualquer. Mas se eu aplicar num select dinâmico, ocorre erro.
      Veja trecho do meu select.
      ... SET @sql = @sql +', dbo.retornaIco_ItemBloq((SELECT COUNT(*) FROM dbo.tab AS TT2 WHERE TT2.codCategTreina = CTT.id),'+@title+') AS ''resp''' ... No caso, o primeiro argumento da function dbo.retornaIco_ItemBloq é um SELECT COUNT.
      O segundo argumento é uma variável (que está devidamente declarada e definida).
       
      O erro ocorre porque ao executar (chamando EXEC(@sql) ), o SQL entende que o segundo argumento é uma coluna da consulta principal, pois existe uma vírgula antes da variável @title (que é o segundo argumento da function).
      Repito. Se eu aplicar essa function num select normal, funciona normalmente. Porém, preciso que funcione num SQL dinâmico porque é esse é o padrão que estou adotando para o sistema todo.
       
      A function dbo.retornaIco_ItemBloq faz o seguinte:
      1) Recebe o valor do COUNT e da variável @title
      2) Se o COUNT for maior que  Zero, cria uma tag HTML (uma SPAN), define sua title com o valor da variável @title e passa para uma variável
      3) Retorna o HTML que será exibido no resultado da consulta principal
      É super simples.
       
      Há outra forma de chamar a function?
    • Por mr22robot
      Ola caros amigos. 
      Estou com uma dúvida aqui que embora nao tenho achado ainda uma resposta, acredito que haja.
      Estou estudando a tão sonhada linguagem de programação asp.net core mvc. Linguagem essa que demorei 5 anos pra iniciar os estudos rsrs.
      Mas estou agarrado em uma situação. 
      Estou usando como base de dados nos meus estudos um banco Oracle. Que já tem algumas informações nele. Utilizei o SCAFFOLD para criar as classes e o contexto baseado no banco e tabelas existentes. 
      Porem agora na fase das consultas, estou perdido em como utilizar o IN que eu utilizo no oracle; no LINQ.
      Ex: 
      SELECT CODPROD,DESCRICAO FROM PRODUTO WHERE CODPROD IN(1,2,3,4,5,6) Como eu utilizo esse filtro com uma restrição de códigos de produtos? no caso o where codprod in(1,2,3,4,5,6) ?.
      Desde já obrigado pela ajuda.
    • Por Sapinn
      Olá a todos existe alguma maneira de trazer todos os dados de uma tabela menos o maior valor?
    • Por Wandersonwfs
      Bom dia Pessoal,
       
      Estou com um problema para finalizar uma consulta onde, quando executado a consulta  e não encontrado nenhuma informação no período solicitado, tenho que trazer pelo menos o nome da conta.
       
      Consulta,
       
      WITH TMPESTONO (
          NOME_IMPOSTO
          ,MES
          ,VALOR
          )
      AS (
          SELECT 'ESTORNO SOBRE GREEN VILLE' AS NOME_IMPOSTO
              ,'F_' + SZN.ZN_ITEM AS FILFOR
              ,SUM((SZN.ZN_PRV * SZN.ZN_PRCAPL) / 100) AS TOTAL
          FROM SZN010 SZN
          WHERE SZN.D_E_L_E_T_ = ' '
              AND SZN.ZN_ITEM IN (
                  '01'
                  ,'16'
                  ,'30'
                  ,'40'
                  ,'46'
                  ,'51'
                  ,'52'
                  ,'60'
                  ,'70'
                  ,'72'
                  ,'73'
                  ,'80'
                  )
              AND SZN.ZN_DATA BETWEEN '20220701'
                  AND '20220731'
              AND SZN.ZN_DESC = ('GRENVILLE')
          GROUP BY SZN.ZN_DESC
              ,SZN.ZN_ITEM
          )
      SELECT *
      FROM (
          SELECT NOME_IMPOSTO
              ,MES
              ,VALOR
          FROM TMPESTONO
          ) AS PivotData
      PIVOT(SUM(VALOR) FOR MES IN (
                  [F_16]
                  ,[F_30]
                  ,[F_40]
                  ,[F_46]
                  ,[F_51]
                  ,[F_52]
                  ,[F_60]
                  ,[F_70]
                  ,[F_72]
                  ,[F_73]
                  ,[TOTAL]
                  )) AS PivotTable2
      ORDER BY 1
       
×

Informação importante

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