[firebase-br] Duvida em Left Outer Join

Eduardo Jedliczka eduardo em gerasoft.com.br
Qui Mar 10 13:13:56 -03 2005


Carvalho, seu problema é de lógica...

O Left Outer Join, vai trazer os que tem e os que não tem lançamentos...
hehehe...

O Mais certo seria utilizar um "Exists"...

Select dados_da_nota from tabela A
where not exists ( select first 1 qualquercoisa from tabela B where
A.dtEmissao=B.dtEmissao and A.OutrosCampos=B.outrosCampos)

Naturalmente o select acima não funciona, mas dá para entender...

[s]

==========================
Eduardo Jedliczka
Gerasoft Informática
Apucarana - Pr
==========================

----- Original Message ----- 
From: "Carvalho" <carvalho em invitro.com.br>
To: <lista em firebase.com.br>
Sent: Thursday, March 10, 2005 12:37 PM
Subject: [firebase-br] Duvida em Left Outer Join


In Vitro Diagnóstica S/A
Caros colaboradores,

Bom dia!

Estou tentando fazer um select para retornar somente registros em aberto
baseado no campo DtEmissao e que não tenha um registro de crédito e somente
de débito.

Um registro de débito não está mais em aberto quando eu tenho um outro
registro de crédito fechando a fatura do cliente.

Vejam um exemplo:
DtEmissao     Cliente    VrDebito   VrCredito   Vencimento    Numero
Parcela
16/12/2004    1640         490,80                      14/01/2005      49201
1
16/12/2004    1640                           490,80    20/01/2005      49201
1

O Select abaixo está me retornando o seguinte:

DtEmissao     Cliente    VrDebito   VrCredito   Vencimento    Numero
Parcela
16/12/2004    1640         490,80                      14/01/2005      49201
1

E na verdade não deveria retornar nada, pois eu tenho um registro matando o
outro.

O que está errado?

Select MF.Numero, MF.NumDoc, MF.NumParcela, MF.VrDeb, MF.DtEmissao,
MF.DtVenc, MF.CodCli, C.Nome, C.Cidade, C.ContaCtb from MovFinanc MF
Left Outer Join Cliente C on C.Codigo = MF.CodCli

Left Outer Join MovFinanc MF2 on MF2.Numero = MF.Numero
and MF2.NumDoc = MF.NumDoc and MF2.NumParcela = MF.NumParcela
and MF2.CodCli = MF.CodCli and MF2.VrCred is not null

where MF.DtEmissao <= '01/31/2005' and MF.VrDeb is not Null
and MF.CodCli = 1640 and MF2.VrCred is null

group by MF.Numero, MF.NumDoc, MF.NumParcela, MF.VrDeb, MF.DtEmissao,
MF.DtVenc, MF.CodCli, C.Nome, C.Cidade, C.ContaCtb

Order by C.Nome

Grato pela colaboração.


----------------------------------------------------------------------------
----


______________________________________________
FireBase-BR (www.firebase.com.br) - Hospedado em www.bavs.com.br
Para editar sua configuração na lista, use o endereço
http://mail.firebase.com.br/mailman/listinfo/lista_firebase.com.br





Mais detalhes sobre a lista de discussão lista