Foros del Web » Programando para Internet » PHP »

Suma While

Estas en el tema de Suma While en el foro de PHP en Foros del Web. Wenas,, Estoy con un problema no es dificil creo pero no me doy cuenta como se haria... El problema es que necesito hacer una suma ...
  #1 (permalink)  
Antiguo 02/03/2012, 07:40
Avatar de Maganius  
Fecha de Ingreso: septiembre-2010
Mensajes: 310
Antigüedad: 13 años, 6 meses
Puntos: 10
Suma While

Wenas,,

Estoy con un problema no es dificil creo pero no me doy cuenta como se haria...

El problema es que necesito hacer una suma dentro de un while de cuantos ID existen iguales

Les muestro un ejemplo

Código HTML:
Ver original
  1. <table width="69" border="0" cellspacing="0" cellpadding="0">
  2.   <tr>
  3.     <td width="69" align="center">ID</td>
  4.   </tr>
  5.   <tr>
  6.     <td>1 (2)</td>
  7.   </tr>
  8.   <tr>
  9.     <td>1 (2)</td>
  10.   </tr>
  11.   <tr>
  12.     <td>2 (2)</td>
  13.   </tr>
  14.   <tr>
  15.     <td>2 (2)</td>
  16.   </tr>
  17.   <tr>
  18.     <td>3 (1)</td>
  19.   </tr>
  20.   <tr>
  21.     <td>4 (4)</td>
  22.   </tr>
  23.   <tr>
  24.     <td>4 (4)</td>
  25.   </tr>
  26.   <tr>
  27.     <td>4 (4)</td>
  28.   </tr>
  29.   <tr>
  30.     <td>4 (4)</td>
  31.   </tr>

El php seria así:

Código PHP:
Ver original
  1. $select = "select * from tabla";
  2. $query = mysql_query($select,$con);
  3.  
  4. $sumo = 1;
  5. while($row = mysql_fetch_object($query)){
  6.  
  7.         //$row->id; aca tengo que saber cuantos id existen iguales
  8.  
  9.         if($row->id==$id_anterior){
  10.           $sumo = $sumo++;
  11.         }else{
  12.           $sumo = 1;
  13.         }
  14.         $id_anterior = $row->id;
  15.         echo $row->id."(".$sumo.")";
  16. }

Lo que hice ahi fue, ver si el id anterior es el mismo que el que entra sumo 1, si es diferente empiezo a contar de nuevo.

pero el problema es que me saca los resultados asi:


Código HTML:
Ver original
  1. <table width="69" border="0" cellspacing="0" cellpadding="0">
  2.   <tr>
  3.     <td width="69" align="center">ID</td>
  4.   </tr>
  5.   <tr>
  6.     <td>1 (1)</td>
  7.   </tr>
  8.   <tr>
  9.     <td>1 (2)</td>
  10.   </tr>
  11.   <tr>
  12.     <td>2 (1)</td>
  13.   </tr>
  14.   <tr>
  15.     <td>2 (2)</td>
  16.   </tr>
  17.   <tr>
  18.     <td>3 (1)</td>
  19.   </tr>
  20.   <tr>
  21.     <td>4 (1)</td>
  22.   </tr>
  23.   <tr>
  24.     <td>4 (2)</td>
  25.   </tr>
  26.   <tr>
  27.     <td>4 (3)</td>
  28.   </tr>
  29.   <tr>
  30.     <td>4 (4)</td>
  31.   </tr>

Y yo quiero que me saque los resultados como el primero ejemplo
ID - 1 (2)
ID - 1 (2)

Siempre con la cantidad final, pero no logro hacerlo tal vez alguien me pueda dar una mano.
  #2 (permalink)  
Antiguo 02/03/2012, 09:53
 
Fecha de Ingreso: enero-2012
Mensajes: 17
Antigüedad: 12 años, 3 meses
Puntos: 4
Respuesta: Suma While

porque no usas un count o group by en la consulta sql.

y te esta imprimiendo todo los resultados porque el echo lo tienen en todo el ciclo.


tambien podrias crearte un arreglo con indice id y cada vez que se repita le agregas un elemento a ese indice u una suma de alguna de las pocisiones.


saludos.
  #3 (permalink)  
Antiguo 04/03/2012, 03:36
Avatar de repara2  
Fecha de Ingreso: septiembre-2010
Ubicación: München
Mensajes: 2.445
Antigüedad: 13 años, 7 meses
Puntos: 331
Respuesta: Suma While

Código PHP:
Ver original
  1. <?php
  2. ini_set("display_errors", 1);
  3. $ids = array(1,2,3,2,3,4,5,4,3,4,5,6,7,6,7,8,9,8,9,8,7,6,5,4);
  4.  
  5. $resultados = array();
  6. for($i = 0; $i<count($ids); $i++)
  7. {
  8.     if(!array_key_exists($ids[$i], $resultados)) $resultados[$ids[$i]] = 1;
  9.     else $resultados[$ids[$i]]++;
  10. }
  11.  
  12. echo "<pre>";
  13. echo "<h3>Origen:</h3>";
  14. print_r($ids);
  15. echo "<h3>Recuento:</h3>";
  16. print_r($resultados);
  17. echo "</pre>";
  18. ?>
__________________
Fere libenter homines, id quod volunt, credunt.

Etiquetas: mysql, suma, tabla
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 10:41.