[firebase-br] RES: Duvida na melhor maneira de fazer um Select
Ivan Guimarães Meirelles
igmeirelles em gmail.com
Qua Jul 4 14:39:45 -03 2007
Olá Forrest...
Com esse select vc está tentando retornar o código do cliente que está na
tabela VENDAS mas que não comprou até uma determinada data. Por isso não
está te retornando nada.
Tente fazer dessa forma:
select c.COD_CLIENTE from CLIENTES c
where c.COD_CLIENTE not in (select distinct v.COD_CLIENTE from VENDAS v
where v.DATA_VENDA < :DATAVENDA)
Acho que assim deve funcionar.
Um abraço...
Ivan Guimarães Meirelles
Três Lagoas/MS - igmeirelles em gmail.com
-----Mensagem original-----
De: lista-bounces em firebase.com.br [mailto:lista-bounces em firebase.com.br] Em
nome de Forrest®
Enviada em: quarta-feira, 4 de julho de 2007 15:20
Para: lista em firebase.com.br
Assunto: [firebase-br] Duvida na melhor maneira de fazer um Select
Boa Tarde pessoal vou tentar explicarm minha duvida.
Estou usando o FB 1.5.3 e tenho uma tabela com a seguinte estrutura
resumida
VENDAS
------
Cod_Venda (PK)
Cod_Cliente (FK de CLIENTES)
Data_Venda
Eu preciso fazer um select para pegar todos os clientes que não possuí
nenhuma venda apartir de uma data que eu informo. Gostaria de saber a
melhor forma de fazer isso, já tentei usando um sub-select mas ficou
muito lento. Alguém poderia dar exemplos da melhor maneira? O Select
que montei e Ficou lento foi o Seguinte e nen sei se está certo tb
dessa maneira. Qualquer ajuda será bem vinda.
SELECT DISTINCT(V1.COD_CLIENTE) AS CLIENTE1
FROM VENDAS V1
WHERE (DATA_VENDA < :DATAVENDA) AND
(V1.COD_CLIENTE NOT IN (SELECT DISTINCT(V2.COD_CLIENTE) AS
CLIENTE2 FROM VENDAS V2 WHERE (V2.DATA_VENDA = :DATAVENDA)))
T++++++++++++++
--
______________________________________________
FireBase-BR (www.firebase.com.br) - Hospedado em www.locador.com.br
Para editar sua configuração na lista, use o endereço
http://mail.firebase.com.br/mailman/listinfo/lista_firebase.com.br
Para consultar mensagens antigas: http://firebase.com.br/pesquisa
Mais detalhes sobre a lista de discussão lista