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 13-04-2010
Poke Poke is offline
Miembro
 
Registrado: dic 2005
Ubicación: Madrid
Posts: 27
Poder: 0
Poke Va por buen camino
Wink Ayuda group by x fecha¡¡¡

Hola a todos no sabía que título poner… tengo la siguiente duda sobre una consulta trabajo con zquery y firebird

Tengo una tabla apuntes con los siguientes campos
Apuntes:
Código
Categoría
Codcate
fechaA
Cargo
abono

Ahora realizo una consulta de la siguientes forma:
Código SQL
Código SQL [-]
select categoria, sum(cargo) as cargo1, sum(abono) as abono1 from apuntes group by categoria

Hasta ahí todo bien me devuelve la suma de todas las categoría pero ahora quiero hacer el mismo proceso pero de fecha ha fecha.. con el campo fecha que tengo en la tabla. Cualquier comentario me sería muy útil desde ya gracias…
__________________
¡Caer está permitido. Levantarse es obligatorio!.
Responder Con Cita
  #2  
Antiguo 13-04-2010
Avatar de Caral
[Caral] Caral is offline
Miembro Premium
 
Registrado: ago 2006
Posts: 7.659
Poder: 25
Caral Va por buen camino
Hola
Tal vez.....
Código Delphi [-]
select categoria, sum(cargo) as cargo1, sum(abono) as abono1 from apuntes where FechaA >= :Fech1 And FechaA <= :Fech2 group by categoria
Saludos
__________________
Siempre Novato
Responder Con Cita
  #3  
Antiguo 13-04-2010
Avatar de Chris
[Chris] Chris is offline
Miembro Premium
 
Registrado: abr 2007
Ubicación: Jinotepe, Nicaragua
Posts: 1.678
Poder: 19
Chris Va por buen camino
No se entiende de forma precisa lo que quieres. Puede ser algo cómo lo propuesto por caral, o bien hacer el GROUP BY usando un rango de fechas a cómo lo estás haciendo ahora con la Categoría.

Si es el segudo caso, puedes hacerlo ya sea cambiando en el SQL el campo Categoría por el de Fecha. Es tan sencillo que dudo que ésta sea tu inquietud :P

Puedes organizarlo por año, o bien por año y mes. Colocando una formula después del GROUP BY, exactamente en donde se encuentra "categoria". Creo que la formula para organizar por años es algo así:

Código SQL [-]
select ... GROUP BY (extract(year from Tabla.Fecha))

Espero te sirva.

Saludos,
Chris.
__________________
Perfil Github - @chrramirez - Delphi Blog - Blog Web
Responder Con Cita
  #4  
Antiguo 13-04-2010
Poke Poke is offline
Miembro
 
Registrado: dic 2005
Ubicación: Madrid
Posts: 27
Poder: 0
Poke Va por buen camino
Gracias x sus respuestas hago de la forma de caral pero nada ..
Código Delphi [-]
ZQueryc.Close;
ZQueryc.SQL.Clear;
ZQueryc.SQL.Add('select categoria, sum(cargo) as cargo1, sum(abono) as abono1 from apuntes');
ZQueryc.SQL.Add('where FechaA  between :Fech1 and :Fech2  group by categoria');
ZQueryc.ParamByName('fech1').DataType := ftdate;
ZQueryc.ParamByName('fech1').Value := strtodate('20/03/2010');
ZQueryc.ParamByName('fech2').DataType := ftdate;
ZQueryc.ParamByName('fech2').Value := strtodate('20/04/2010');
ZQueryc.Open;
Me sale error ¡¡ no reconoce el campo fecha es x que no la declaro en el select pero si la declaro no me sale el resultado que quiero… quiero que sume el cargo o abono de las categorías de x fecha a x fecha…
No se si me hago entender es que soy novato en estoo…
__________________
¡Caer está permitido. Levantarse es obligatorio!.
Responder Con Cita
  #5  
Antiguo 13-04-2010
Avatar de Caral
[Caral] Caral is offline
Miembro Premium
 
Registrado: ago 2006
Posts: 7.659
Poder: 25
Caral Va por buen camino
Hola
La verdad no entiendo, yo lo haria asi:
Código Delphi [-]
ZQueryc.Close;
ZQueryc.SQL.Text:= 'select categoria, sum(cargo) as cargo1, sum(abono) as abono1 from apuntes'+
                   ' where FechaA  between :Fech1 and :Fech2  group by categoria';
ZQueryc.ParamByName('Fech1').Value := strtodate('20/03/2010');
ZQueryc.ParamByName('Fech2').Value := strtodate('20/04/2010');
ZQueryc.Open;
A ver....
Saludos
__________________
Siempre Novato
Responder Con Cita
  #6  
Antiguo 13-04-2010
Poke Poke is offline
Miembro
 
Registrado: dic 2005
Ubicación: Madrid
Posts: 27
Poder: 0
Poke Va por buen camino
Gracias x tu respuesta caral pero lo que tu planteas es lo mismo.. el error que me da es que no reconoce el campo fechaa para que funcione con el campo fecha debo ponerla en el select asi:


Código Delphi [-]
select fechaa, categoria, sum(cargo) as cargo1, sum(abono) as abono1 from apuntes
where FechaA  between :Fech1 and :Fech2  group by categoria, fechaa';

Pero al momento de agrupar me agrupan tb con el campo fecha. Y es lo que no quiero… mm no sé cómo hacerlo he buscado x el foro y no encuentro nada parecido.. mm a ver si me pueden ayudar…
__________________
¡Caer está permitido. Levantarse es obligatorio!.

Última edición por Poke fecha: 25-04-2010 a las 17:35:56.
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
Ayuda con group by nikotina SQL 5 23-06-2008 14:32:43
Impresion de group header group footer Manuel Impresión 3 11-11-2007 01:05:23
Ayuda, Como calcular fecha de vencimiento mensual a partir de una fecha x en delphi Renis Impresión 4 23-08-2007 23:45:14
consultas anidadas: group by dentro otro group by DobleSiete SQL 7 31-01-2005 14:59:31
Group Header, Detail y Footer Group en la misma pagina MarcelRuz Impresión 0 20-04-2004 23:27:14


La franja horaria es GMT +2. Ahora son las 06:50:51.


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