Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Bases de datos > Firebird e Interbase
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 26-01-2012
MartinS MartinS is offline
Miembro
NULL
 
Registrado: nov 2011
Ubicación: Villa Cacique - Argentina
Posts: 283
Poder: 13
MartinS Va por buen camino
No funciona consulta agrupada

Hola. Tengo que agrupar una consulta de personal por sector de trabajo. Aparentemente no debería haber inconvenientes pero me da un error. He consultado por los hilos correspondientes del foro y parecería que la instrucción que ejecuto esta bien:

Código Delphi [-]
  With Filtro do
  Begin
    Close;
    Sql.Clear;
    Sql.Add('Select Id, Nombres, NroLegajo, HORTRABAJO, SECTTRABAJO From Agentes');
    SQL.Add('GROUP BY SECTTRABAJO');
    SQL.Add('Order by apellido');
    Open;
  End;

a su vez necesito contar cuantos hay en cada grupo pero lo importante es que primero agrupe.

El error que da es Dynamic SQL error code =-104
Dumped xxxxxxx pages of a total 0 database pages.

Es una base Firebird y Filtro es un IBQuery
Gracias y saludos
Responder Con Cita
  #2  
Antiguo 26-01-2012
Avatar de guillotmarc
guillotmarc guillotmarc is offline
Miembro
 
Registrado: may 2003
Ubicación: Huelva
Posts: 2.638
Poder: 23
guillotmarc Va por buen camino
Hola.

Cita:
Empezado por MartinS Ver Mensaje
Hola. Tengo que agrupar una consulta de personal por sector de trabajo. Aparentemente no debería haber inconvenientes pero me da un error. He consultado por los hilos correspondientes del foro y parecería que la instrucción que ejecuto esta bien:

Código Delphi [-] With Filtro do Begin Close; Sql.Clear; Sql.Add('Select Id, Nombres, NroLegajo, HORTRABAJO, SECTTRABAJO From Agentes'); SQL.Add('GROUP BY SECTTRABAJO'); SQL.Add('Order by apellido'); Open; End;


a su vez necesito contar cuantos hay en cada grupo pero lo importante es que primero agrupe.

El error que da es Dynamic SQL error code =-104
Dumped xxxxxxx pages of a total 0 database pages.

Es una base Firebird y Filtro es un IBQuery
Gracias y saludos
No, esta consulta no está bien. Cuando haces una consulta con agrupación, todos los campos devueltos tienen que estar o bien bajo una función de agrupación (sum(), min(), max(), ...) o bien dentro de la lista de campos a agrupar (cláusula GROUP BY).

Tu consulta no tiene sentido. ¿ Si quieres agrupar los agentes por SECTTRABAJO, como esperas a la vez que la consulta te devuelva el ID de dichos AGENTES ?.

Probablemente esta consulta sea más parecida a lo que estás buscando :

Código SQL [-]
Select Id, Nombres, NroLegajo, HORTRABAJO, SECTTRABAJO 
From Agentes
Order by SECTTRABAJO, apellido

Saludos.
__________________
Marc Guillot (Hi ha 10 tipus de persones, els que saben binari i els que no).

Última edición por guillotmarc fecha: 26-01-2012 a las 15:24:48.
Responder Con Cita
  #3  
Antiguo 26-01-2012
MartinS MartinS is offline
Miembro
NULL
 
Registrado: nov 2011
Ubicación: Villa Cacique - Argentina
Posts: 283
Poder: 13
MartinS Va por buen camino
Hola. Ahora sí. ya comprendí cual es el error.

la idea era que me diera la cantidad de agentes que hay en cada sector y gracias a tu respuesta descifre, aunque parezca mentira, lo que realmente necesitaba. Lo resolví asi:

Código Delphi [-]
With Filtro do
  Begin
    Close;
    Sql.Clear;
    Sql.Add('Select SectTrabajo, count(Id) As Total');
    Sql.Add('From Agentes');
    Sql.Add('Group By SectTrabajo');
    Open;
  End;

ahora puedo ver en un Dbgrid cuantos empleados tiene cada sector. Gracias!!!
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
Consulta sql solo funciona una vez webmasterplc SQL 2 16-02-2011 16:40:41
consulta agrupada y ordenada ZLEON SQL 4 19-11-2008 15:19:11
Esta consulta no me funciona brandolin Firebird e Interbase 1 12-02-2007 17:29:08
Por que no me funciona esta consulta SQL en mi programa? IcebergDelphi Firebird e Interbase 2 15-09-2003 04:12:07
Consulta Interbase con CGI No Funciona ASAPLTDA Internet 2 26-06-2003 23:15:42


La franja horaria es GMT +2. Ahora son las 18:13:10.


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