Foros del Web » Programando para Internet » PHP »

Dudas con un SELECT por edad

Estas en el tema de Dudas con un SELECT por edad en el foro de PHP en Foros del Web. Hola: Tengo una Base de Datos MySQL con datos de alumnos, en la que tengo entre otros campos, el nombre de alumno, dia de nacimiento, ...
  #1 (permalink)  
Antiguo 21/02/2008, 06:12
 
Fecha de Ingreso: noviembre-2005
Mensajes: 86
Antigüedad: 18 años, 5 meses
Puntos: 0
Dudas con un SELECT por edad

Hola: Tengo una Base de Datos MySQL con datos de alumnos, en la que tengo entre otros campos, el nombre de alumno, dia de nacimiento, mes y año.

El problema es que estoy intentando hacer una página de busqueda, en la que pueda elegir mediante opciones <select> una consulta de los alumnos que hay de un grupo de edades determinadas, por ejemplo los que hay entre 10 y 12 años.

He probado varios scripts,pero la consulta me devuelve la edad incorrecta, porque solo me resta los años, pero no tiene en cuenta los que les faltan varios meses para cumplirlos.

La duda que tengo es si se puede hacer la consulta con un script a partir de los campos dia_nacimiento, mes_nacimiento y anio_nacimiento, o es necesario poner un nuevo campo "edad" y modificar la BD antes de hacer la consulta.

La edad si que la se calcular despues de una consulta y me da una variable $edad, pero eso no me permite hacer un SELECT comparandola con ningun campo, ya que ese campo "edad" no existe.

He probado a hacer la consulta con este script, pero no me calcula bien la edad para hacer la consulta:


<HTML>
<HEAD>
<TITLE>Buscar alumnos dede X edad hasta Y edad, a partir del campo f_nacimiento:Año-Mes-Dia</TITLE>
</HEAD>
<BODY>

<?
$fecha_actual= strtotime(date("Y-m-d"));
//Fecha desglosada
$anio_actual=date("Y", $fecha_actual);
$mes_actual=date("m", $fecha_actual);
$dia_actual=date("d", $fecha_actual);

//Edad menor del intervalo buscado, por ejemplo 10 años
$desde_anios='10';
$anio_nacimiento_desde=$anio_actual-$desde_anios;

// aqui me calcula mal el año de nacimiento, si va a cumplir los años en los próximos meses o dias.
$edad_menor="$anio_nacimiento_desde-$mes_actual-$dia_actual";
echo $edad_menor; echo "<br>";


//Edad máxima del intervalo buscado
$hasta_anios='12';
$anio_nacimiento_hasta=$anio_actual-$hasta_anios;
$edad_mayor="$anio_nacimiento_hasta-$mes_actual-$dia_actual";
echo $edad_mayor; echo "<br>";

include ("conexion.php");
$result = mysql_query("select * from alumnos WHERE f_nacimiento>='$edad_menor' AND f_nacimiento<'$edad_mayor'");
while($row = mysql_fetch_array($result)) {//if1
echo $row["alumnos"];echo "<br>";
} // if1
?>
</BODY>
</HTML>

¿Me dais algún consejo?
  #2 (permalink)  
Antiguo 21/02/2008, 06:15
 
Fecha de Ingreso: noviembre-2005
Mensajes: 86
Antigüedad: 18 años, 5 meses
Puntos: 0
Re: Dudas con un SELECT por edad

Perdón: El encabezamiento y el campo comparado es porque al final he puesto otro campo "f_nacimiento" con el formato AAAA-MM-DD, pero me sigue pasando lo mismo.
  #3 (permalink)  
Antiguo 21/02/2008, 06:21
 
Fecha de Ingreso: junio-2007
Ubicación: por ahi
Mensajes: 262
Antigüedad: 16 años, 10 meses
Puntos: 4
Re: Dudas con un SELECT por edad

Las normas de Normalizacion y la experiencia dicen que nunca debe ser la edad un campo de una base de datos, debe ser siempre calculado. El como se calcula depende de lo que se quiera hacer.

normalmente la consulta se hace desde el SQL mismo sin llevarlo al PHP.

Pero si por algun motivo todavia quieres hacerlo con PHP hay que pasarlo todo a una misma unidad para tener el dato exacto. Como decian en la escuela no se pueden sumar peras con manzanas.

o todo lo pones en a@os o todo en meses o todo en dias, y despues si debe salir correcto el calculo
  #4 (permalink)  
Antiguo 21/02/2008, 07:14
 
Fecha de Ingreso: noviembre-2005
Mensajes: 86
Antigüedad: 18 años, 5 meses
Puntos: 0
Re: Dudas con un SELECT por edad


Creo que entiendo lo que quieres decirme: Hay que convertir primero los datos a dias y luego hacer las restas correspondientes antes de hacer el SELECT.

Probaré. Saludos.
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 23:39.