Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   SQL (https://www.clubdelphi.com/foros/forumdisplay.php?f=6)
-   -   agrupar por rango de edades (https://www.clubdelphi.com/foros/showthread.php?t=6581)

jzginez 13-01-2004 20:41:56

agrupar por rango de edades
 
hola a todos tengo una tabla con los siguientes datos:

Nombre, edad, sexo, si sufre de presión alta, si toma medicina, si a tenido alguna emergencia, si esta en tratamiento medico.

necesito agrupar esta tabla por rango de edades, cuando usa la centencia group by edad me agrupa por un solo valor es decir todos los que tienen 18 años, todos los que tienen 20, 30, 23... etc. lo que necesito es que me agrupo todos los que tienen entre 18 y 25, entre 26 y 40, etc. para poder sacar porcentages, alguien me puede decir como logro esto.

gracias

delphi.com.ar 13-01-2004 21:19:25

Hay muchas formas de hacer esto, una forma puede ser hacer una función en la base que según una tabla te retorne un ID de grupo, entonces agruparas por el resultado de esta función.

O mismo podríamos hacer algo tan sencillo como esto:
Código:

SELECT COUNT(*), R.DESCRIPCION
FROM PERSONAS P, RANGOS R
WHERE p.EDAD BETWEEN R.DESDE AND R.HASTA
GROUP BY R.ID

Suponiendo que tendríamos una tabla de rango similar a:
Código:

CREATE TABLE RANGOS (
  ID NUMBER,
  DESCRIPCION VARCHAR,
  DESDE NUMBER,
  HASTA NUMBER
 )

Datos de rangos tipo:
Código:

ID        DESDE    HASTA
1        0        18
2        19        21
3        22        30
4        31        40
5        41        60
6        61        Máximo Posible

Saludos!

jzginez 14-01-2004 06:01:56

Gracias delphi.com.ar ya habia intentado lo de la tabla de rangos pero la diferencia es que intente mandar los valores del rango como parametros y no me funciono pero estoy seguro que como tu sugieres una consulta combinada si me da lo que busco.


La franja horaria es GMT +2. Ahora son las 12:09:29.

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