Foros del Web » Programando para Internet » PHP »

problema con resultado de un ciclo,....

Estas en el tema de problema con resultado de un ciclo,.... en el foro de PHP en Foros del Web. buen dia por favor tengo uncodigo aka que no me funiona necesito me lo revisen a ver que es lo que tiene mal, supuestamente debe ...
  #1 (permalink)  
Antiguo 20/10/2008, 08:33
Avatar de mahia  
Fecha de Ingreso: enero-2008
Ubicación: La Tierra
Mensajes: 69
Antigüedad: 16 años, 3 meses
Puntos: 0
problema con resultado de un ciclo,....

buen dia por favor tengo uncodigo aka que no me funiona necesito me lo revisen a ver que es lo que tiene mal, supuestamente debe hallarme el menor , y lo hace pero no cuando tengo dos numeros menores iguales osea numeros(1,2,8,45,1) me muestre como resultado (1;1)...
aki les dejo el codigo

if($_POST['radiobutton'] == "menor_mes")
{

$ya=mysql_query("SELECT count(`id_servicio`) AS cuenta, mes from datos where
`id_servicio`='6' GROUP BY `mes`");

$cantidadPorMes = array();
$mes = array();
$valorMin = 0;
$i = 0;

while($row = mysql_fetch_object($ya))
{
$cantidadPorMes[] = $row->cuenta;
$mes[] = $row->mes;
o;
}



/// aqui comienza ....

for($i=0; $i<count($cantidadPorMes)-1; $i++)
{
for($j=i+1; $j<count($cantidadPorMes); $j++)
{
if($cantidadPorMes[$i]<$cantidadPorMes[$j])
{$valorMin=$cantidadPorMes[$i]; $elem=$i;}
else
{$valorMin=$cantidadPorMes[$j]; $elem=$j;}
}
}
$k=0;
for($i=0; $i<count($cantidadPorMes); $i++)
{
if($cantidadPorMes[$i]==$valorMin && $i!=$elem)
{
$menores[$k]=$i;
$k++;
}


}
echo "EL mes de menor valor es: ". $mes[array_search($valorMin, $cantidadPorMes)];
exit();



}
  #2 (permalink)  
Antiguo 20/10/2008, 09:20
Avatar de chitoso  
Fecha de Ingreso: mayo-2008
Ubicación: Montevideo, Uruguay
Mensajes: 205
Antigüedad: 16 años
Puntos: 5
De acuerdo Respuesta: problema con resultado de un ciclo,....

Sinceramente no tengo muchas ganas de revisar ese código, pero te doy una solución alternativa.

Porqué no lo haces directamente en la consulta SQL? Algo así:

Código PHP:
$ya mysql_query("SELECT count(`id_servicio`) AS cuenta, mes from datos where
`id_servicio`='6' GROUP BY `mes` ORDER BY mes ASC LIMIT 1"
); 
Ahí ordenas por mes de menor a mayor y limitas la consulta a un solo resultado. Directamente te quedas con el único resultado y listo!.

Te sirve?
__________________
Pasión por la Música

Última edición por chitoso; 20/10/2008 a las 09:28
  #3 (permalink)  
Antiguo 20/10/2008, 09:41
Avatar de mahia  
Fecha de Ingreso: enero-2008
Ubicación: La Tierra
Mensajes: 69
Antigüedad: 16 años, 3 meses
Puntos: 0
Respuesta: problema con resultado de un ciclo,....

Gracias pero realmente lo que quiero es que me muestre cuantas cantidades de menores iguales exista en la BD... no puedo limitarlo a 1 o 2 resultados debe mostrarme lo que tiene realmente...
igual te lo agradezco
  #4 (permalink)  
Antiguo 20/10/2008, 09:47
Avatar de chitoso  
Fecha de Ingreso: mayo-2008
Ubicación: Montevideo, Uruguay
Mensajes: 205
Antigüedad: 16 años
Puntos: 5
Respuesta: problema con resultado de un ciclo,....

Perdón que insista, pero creo que lo puedes hacer perfectamente a traves de la base de datos. Quizá no entendí bien el problema, o no supiste explicarte bien cual es el objetivo del calculo.

De todas maneras, estaría bueno que ordenes un poco el código y lo pongas entre tags [PHP], por lo menos un indentado, porque la verdad que se ve terrible.
__________________
Pasión por la Música
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 03:29.