Como escrever esta consulta para três tabelas

Android World

Eu tenho 3 mesas

Tabela: agentes

Id | Name
---+------
 1 | a
 2 | b
 3 | c

Mesa: passageiros

Id | AgentReference | Name
---+----------------+-----
 1 |       1        | E
 2 |       1        | F
 3 |       3        | ddd

Tabela: visa_by_agent

Id | agentId | visa_id | Total | Used
---+---------+---------+-------+------
 1 |   1     | aa      |   10  |   1
 2 |   1     | bb      |   20  |   2
 3 |   3     | dd      |   10  |   5

Quero mostrar o resultado como

agentId | agentName | TotalPassenger | TotalVisa | TotalUsed
--------+-----------+----------------+-----------+-----------
   1    | a         |      2         |     30    |     3
   2    | b         |      0         |      0    |     0
   3    | c         |      1         |     10    |     5

Eu tentei com isso e obtive um erro de sintaxe

select  
    a.Id, a.Name, 
    vba.total, vba.used p.num_passengers 
from 
    agents a 
left join 
    (select 
         vba.AgentId, sum(Total) as Total, sum(Used) as Used 
     from 
         visa_by_agent vba 
     group by 
         vba.AgentId) vba on a.Id = vba.AgentId 
left join 
    (select p.AgentReference, count(*) as num_passengers 
     from passengers p 
     group by p.AgentReference) p on a.Id = p.AgentReference 
group by 
    agents.Id
Gordon Linoff

Você está unindo ao longo de diferentes dimensões, resultando em um produto cartesiano. Agregue antes de entrar:

select a.Id, a.Name, vba.total, vba.used, p.num_passengers
from agents a left join
     (select vpa.AgentId, sum(Total) as Total, sum(Used) as Used
      from visa_by_agent vba
      group by vba.AgentId
     ) vba
     on a.Id = vba.AgentId left join
     (select p.agentId, count(*) as num_passengers
      from passengers p
      group by p.agentId
     ) p
     on a.Id = p.AgentId

Este artigo é coletado da Internet.

Se houver alguma infração, entre em [email protected] Delete.

editar em
0

deixe-me dizer algumas palavras

0comentários
loginDepois de participar da revisão

Artigos relacionados

TOP lista

  1. 1

    R Shiny: use HTML em funções (como textInput, checkboxGroupInput)

  2. 2

    O Chromium e o Firefox exibem as cores de maneira diferente e não sei qual deles está fazendo certo

  3. 3

    Como assinar digitalmente um documento PDF com assinatura e texto visíveis usando Java

  4. 4

    R Folheto. Dados de pontos de grupo em células para resumir muitos pontos de dados

  5. 5

    Gerenciar recurso shake de Windows Aero com barra de título personalizado

  6. 6

    Como obter dados API adequados para o aplicativo angular?

  7. 7

    UITextView não está exibindo texto longo

  8. 8

    Por que meus intervalos de confiança de 95% da minha regressão multivariada estão sendo plotados como uma linha de loess?

  9. 9

    Acessando relatório de campanhas na AdMob usando a API do Adsense

  10. 10

    Usando o plug-in Platform.js do Google

  11. 11

    Como posso modificar esse algoritmo de linha de visada para aceitar raios que passam pelos cantos?

  12. 12

    Dependência circular de diálogo personalizado

  13. 13

    Coloque uma caixa de texto HTML em uma imagem em uma posição fixa para site para desktop e celular

  14. 14

    iOS: como adicionar sombra projetada e sombra de traço no UIView?

  15. 15

    Como usar a caixa de diálogo de seleção de nomes com VBA para enviar e-mail para mais de um destinatário?

  16. 16

    Tabela CSS: barra de rolagem para a primeira coluna e largura automática para a coluna restante

  17. 17

    How to create dynamic navigation menu select from database using Codeigniter?

  18. 18

    Converter valores de linha SQL em colunas

  19. 19

    ChartJS, várias linhas no rótulo do gráfico de barras

  20. 20

    用@StyleableRes注释的getStyledAttributes。禁止警告

  21. 21

    não é possível adicionar dependência para com.google.android.gms.tasks.OnSuccessListener

quentelabel

Arquivo