-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathstatement.sql
More file actions
58 lines (43 loc) · 1.6 KB
/
statement.sql
File metadata and controls
58 lines (43 loc) · 1.6 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
SELECT numero, nome FROM banco;
SELECT banco_numero, numero, nome FROM agencia;
--STATEMENT SIMPLES
WITH tbl_tmp_banco AS (
SELECT numero, nome
FROM banco
)
SELECT numero, nome FROM tbl_tmp_banco;
WITH params AS (
SELECT 213 AS banco_numero
), tbl_tmp_banco AS (
SELECT numero, nome FROM banco
JOIN params ON params.banco_numero = banco.numero
)
SELECT numero, nome FROM tbl_tmp_banco;
-- SUB SELECT
SELECT banco.numero, banco.nome FROM banco
JOIN (
SELECT 213 AS banco_numero
) params ON params.banco_numero = banco.numero;
--STATEMENT VARIAS TABELAS
WITH clientes_e_transacoes AS (
SELECT cliente.nome AS cliente_nome, --muda nome do campo
tipo_transacao.nome AS tipo_transacao_nome,
cliente_transacoes.valor AS tipo_transacao_valor
--relação errada
FROM cliente_transacoes
JOIN cliente ON cliente.numero = cliente_transacoes.cliente_numero
JOIN tipo_transacao ON tipo_transacao_id = cliente_transacoes.tipo_transacao_id
)
SELECT cliente_nome, tipo_transacao_nome, tipo_transacao_valor
FROM clientes_e_transacoes ORDER BY cliente_nome;
WITH clientes_e_transacoes AS (
SELECT cliente.nome AS cliente_nome, --muda nome do campo
tipo_transacao.nome AS tipo_transacao_nome, --muda nome do campo
cliente_transacoes.valor AS tipo_transacao_valor --muda nome do campo
--relação correta
FROM cliente
JOIN cliente_transacoes ON cliente_transacoes.cliente_numero = cliente.numero
JOIN tipo_transacao ON tipo_transacao.id = cliente_transacoes.tipo_transacao_id
)
SELECT cliente_nome, tipo_transacao_nome, tipo_transacao_valor
FROM clientes_e_transacoes ORDER BY cliente_nome, tipo_transacao_valor;