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 Buscar Temas de Hoy Marcar Foros Como Leídos

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 07-06-2018
Avatar de Angel.Matilla
Angel.Matilla Angel.Matilla is offline
Miembro
 
Registrado: ene 2007
Posts: 1.350
Poder: 19
Angel.Matilla Va por buen camino
SELECT con SUM y COUNT

Estoy teniendo un problema al que no sé como meterle mano. Tego este query:
Código PHP:
SELECT B.NombreCOUNT(C.Codigo), SUM(D.Censo)
  
FROM DatLoc AJunta BPersona CMesas D
 WHERE A
.Codigo B.Codigo 
   
AND A.Codigo C.Junta 
   
AND C.Situacion IN (12)
   AND 
A.Codigo D.Municipio
   
AND A.Codigo 39
 GROUP BY 1 
Vamos por partes. Digamos que "contando a pelo" sé que el resultado del COUNT para esos datos es de 907 y el SUM tiene que salir 58211. Eso es así sí o sí.


Si hago el SELECT sólo con el COUNT (SELECT B.Nombre, COUNT(C.Codigo)) o sólo con el SUM (SELECT B.Nombre, SUM(D.Censo)) me salen los resultados que he puesto más arriba, pero si combino ambas operaciones tal como en el código me da como resultado 90.700 para el COUNT y 52.797.377 para el SUM. Y me estoy volviendo loco tratando de averiguar porqué salen esos resultados.
Responder Con Cita
  #2  
Antiguo 07-06-2018
manelb manelb is offline
Miembro
 
Registrado: mar 2017
Posts: 280
Poder: 8
manelb Va por buen camino
Yque resultado muestra si pones
Código SQL [-]
SELECT B.Nombre, COUNT(*), SUM(D.Censo)
  FROM DatLoc A, Junta B, Persona C, Mesas D
 WHERE A.Codigo = B.Codigo 
   AND A.Codigo = C.Junta 
   AND C.Situacion IN (1, 2)
   AND A.Codigo = D.Municipio
   AND A.Codigo = 39
 GROUP BY 1
Responder Con Cita
  #3  
Antiguo 07-06-2018
Avatar de Angel.Matilla
Angel.Matilla Angel.Matilla is offline
Miembro
 
Registrado: ene 2007
Posts: 1.350
Poder: 19
Angel.Matilla Va por buen camino
Cita:
Empezado por manelb Ver Mensaje
Yque resultado muestra si pones
Lo mismo: 90700 y 52797377
Responder Con Cita
  #4  
Antiguo 07-06-2018
Avatar de Angel.Matilla
Angel.Matilla Angel.Matilla is offline
Miembro
 
Registrado: ene 2007
Posts: 1.350
Poder: 19
Angel.Matilla Va por buen camino
El problema creo que ha de estar en como relacionar las tablas Junta y Mesas, que al poner ambos contadores pasa más de una vez por cada registro. Si no es así, no lo entiebdo.
Responder Con Cita
  #5  
Antiguo 07-06-2018
Avatar de mamcx
mamcx mamcx is online now
Moderador
 
Registrado: sep 2004
Ubicación: Medellín - Colombia
Posts: 3.911
Poder: 25
mamcx Tiene un aura espectacularmamcx Tiene un aura espectacularmamcx Tiene un aura espectacular
Por lo tanto debes poner el codigo en el group by. (y pon un order by para que la consulta sea estable)

La otra, pon un ejemplo de los datos con valores duplicados pa que veamos como estan...
__________________
El malabarista.
Responder Con Cita
  #6  
Antiguo 07-06-2018
manelb manelb is offline
Miembro
 
Registrado: mar 2017
Posts: 280
Poder: 8
manelb Va por buen camino
Cita:
Empezado por mamcx Ver Mensaje
(y pon un order by para que la consulta sea estable)
Perdona mi ignorancia pero, ¿podrías comentar esto??
Responder Con Cita
Respuesta


Herramientas Buscar en Tema
Buscar en Tema:

Búsqueda Avanzada
Desplegado

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
¿Select count sin group by? zazexx SQL 5 07-08-2008 16:27:11
Ayuda con Select Count aanil SQL 16 13-05-2008 23:12:34
Mejorar SELECT COUNT ferjavrec2 SQL 0 01-06-2007 22:00:00
valor de SELECT COUNT maruenda SQL 15 25-05-2007 23:58:38
Select Count (distinct X) lunatiko SQL 2 17-10-2004 22:06:45


La franja horaria es GMT +2. Ahora son las 17:37:42.


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