Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > SQL
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 25-08-2008
Avatar de chinosoft
chinosoft chinosoft is offline
Miembro
 
Registrado: nov 2006
Posts: 28
Poder: 0
chinosoft Va por buen camino
Question Consulta SQL

Buenas:

Estoy haciendo una aplicacion de escritorio (con FireBird), donde necesito un listado de los ultimos pedidos realizados por cada cliente.

En la tabla pedido tengo los siguientes campos

numero, fecha, id_cliente, nombredelpedido

y la consulta que realizo es la siguiente

Código SQL [-]
select
    numero, nombre

from
    pedido

where
    numero in (select max(numero) as numero, id_cliente from trabajo group by id_cliente);

esta consulta me da un error
"Invalid token. Dynamic SQL Error. SQL error code = -104. Invalid command.
count of column list and variable list do not match."

Agradesco cualquier pista que puedan tirarme!

desde ya agradecido!

__________________
:D chinosoft - only
Responder Con Cita
  #2  
Antiguo 25-08-2008
pcicom pcicom is offline
Miembro
 
Registrado: may 2003
Ubicación: MONTERREY MEXICO
Posts: 253
Poder: 22
pcicom Va por buen camino
Generalmente las ordenes o comandos MAX, SUM, MIN... deben de estar despues de los campos que utilizaras en GROUP BY..

Código SQL [-]
select numero, nombre from pedido
where
    numero in (select max(numero) as numero from trabajo group 
by id_cliente);

OTRA FORMA SERIA

Código SQL [-]

select a.id_cliente,b.nombre from trabajo a
   LEFT JOIN pedido b ON a.id_cliente=b.id_cliente

Saludos..
__________________
Poco ha de saber el que no pregunta.. Yo por eso soy un pregunton

Última edición por pcicom fecha: 25-08-2008 a las 15:59:25.
Responder Con Cita
  #3  
Antiguo 25-08-2008
Avatar de Caro
*Caro* Caro is offline
Moderadora
 
Registrado: jul 2004
Ubicación: Cochabamba, Bolivia
Posts: 2.544
Poder: 22
Caro Va por buen camino
Hola chinosoft, te da error porque en tu segunda consulta estas devolviendos 2 campos, para que lo tome el in debes devolver solo un campo

Código SQL [-]
select numero, nombre
from pedido
where numero in (select max(numero) as numero from trabajo group by id_cliente);

Saluditos
__________________
Disfruten cada minuto de su vida a lado de sus seres queridos como si fuese el ultimo, uno nunca sabe lo que puede pasar.
Responder Con Cita
  #4  
Antiguo 25-08-2008
Avatar de chinosoft
chinosoft chinosoft is offline
Miembro
 
Registrado: nov 2006
Posts: 28
Poder: 0
chinosoft Va por buen camino
Muchas gracias a los 2! por su pronta respuestaaaa!!

Caro tenias razon con los de en mi segunda consulta, esta devolviendo 2 campos.

Muchas graciasss
__________________
:D chinosoft - only
Responder Con Cita
Respuesta



Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro

Temas Similares
Tema Autor Foro Respuestas Último mensaje
Realizar una consulta sobre los registros que devuelve otra consulta Borjaserrano Firebird e Interbase 12 01-10-2007 23:19:44
Consulta dentro de otra consulta judit25 Conexión con bases de datos 1 25-06-2007 15:52:15
consulta sobre consulta superhopi SQL 2 16-05-2003 19:01:47


La franja horaria es GMT +2. Ahora son las 11:38:11.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi