Foros del Web » Programando para Internet » PHP »

Datos de un campo como cabecera

Estas en el tema de Datos de un campo como cabecera en el foro de PHP en Foros del Web. Buenas tardes compañeros. Me surge el siguiente problema. Tengo una tabla con 3 campos. Nombre tarea y tiempo. En Nombre tengo A,B,C,D en tarea tengo ...
  #1 (permalink)  
Antiguo 07/09/2012, 12:31
 
Fecha de Ingreso: diciembre-2011
Ubicación: Ourense España
Mensajes: 10
Antigüedad: 12 años, 3 meses
Puntos: 0
Datos de un campo como cabecera

Buenas tardes compañeros.
Me surge el siguiente problema.
Tengo una tabla con 3 campos. Nombre tarea y tiempo.
En Nombre tengo A,B,C,D en tarea tengo 1,2,3 y en tiempo 20,50,30,50

si hago una consulta me aparece:

Nombre tarea tiempo
A 1 20
B 1 50
C 2 50
C 1 60
A 2 80
A 3 10
B 2 10
B 3 5
C 3 25

Quiero que aparezca la consulta de la siguiente forma:

Nombre Tarea 1 Tarea 2 Tarea 3
A 20 80 10
B 50 10 5
C 60 50 25

Y no tengo claro como realizar la consulta.
Agradeciendo de antemano vuestra ayuda recibid un cordial saludo
Juanka
  #2 (permalink)  
Antiguo 07/09/2012, 13:16
Avatar de PIRRUMAN  
Fecha de Ingreso: febrero-2006
Ubicación: Monterrey, Nuevo León
Mensajes: 633
Antigüedad: 18 años, 2 meses
Puntos: 53
Respuesta: Datos de un campo como cabecera

prueba con group by

al final group by Nombre
__________________
“Prefiero ser un tonto momentaneo que un eterno ignorante”
“¡El éxito es resultado de los aciertos,los aciertos resultado de la experiencia y la experiencia resultado de los errores!”
  #3 (permalink)  
Antiguo 08/09/2012, 09:13
 
Fecha de Ingreso: diciembre-2011
Ubicación: Ourense España
Mensajes: 10
Antigüedad: 12 años, 3 meses
Puntos: 0
Respuesta: Datos de un campo como cabecera

Cita:
Iniciado por PIRRUMAN Ver Mensaje
prueba con group by

al final group by Nombre
Gracias por responder pero el problema es como monto la visualizacion de la consulta en php

Saludos y gracias anticipadas
  #4 (permalink)  
Antiguo 11/09/2012, 10:49
 
Fecha de Ingreso: diciembre-2011
Ubicación: Ourense España
Mensajes: 10
Antigüedad: 12 años, 3 meses
Puntos: 0
Respuesta: Datos de un campo como cabecera

¿no habrá algún amable compañero que pueda resolverme este problema?
Gracias de antemano
  #5 (permalink)  
Antiguo 11/09/2012, 11:08
Avatar de PIRRUMAN  
Fecha de Ingreso: febrero-2006
Ubicación: Monterrey, Nuevo León
Mensajes: 633
Antigüedad: 18 años, 2 meses
Puntos: 53
Respuesta: Datos de un campo como cabecera

todos tendrian la misma cantidad de tareas? es decir

A puede tener 2 tares y B y C tres?

llevas algo de codigo intentado?
__________________
“Prefiero ser un tonto momentaneo que un eterno ignorante”
“¡El éxito es resultado de los aciertos,los aciertos resultado de la experiencia y la experiencia resultado de los errores!”
  #6 (permalink)  
Antiguo 14/09/2012, 23:58
 
Fecha de Ingreso: diciembre-2011
Ubicación: Ourense España
Mensajes: 10
Antigüedad: 12 años, 3 meses
Puntos: 0
Respuesta: Datos de un campo como cabecera

Hola,
Gracais por responder

En principio siempre serian las mismas tareas aunque si alguno no la realiza pues aparecería en blanco o simplemente pondría giones

Solo tengo el codigo de llamada mysql e intente con esto
Código:
$cantresult = mysql_num_rows($resultados);

echo "<table border = '1'> \n";

echo "<tr> \n";

echo "<td><b>Referencia</b></td> \n";

echo "<td><b>Of</b></td> \n";

echo "<td><b>tarea20</b></td> \n";

echo "<td><b>tarea50</b></td> \n";

echo "<td><b>Tiempo total</b></td> \n";

echo "<td><b>tiempo</b></td> \n";

echo "<td><b>Observaciones</b></td> \n";

echo "</tr> \n";



while ($row = mysql_fetch_array($resultados)){
	
	
echo "<tr> \n";
if ($row["tarea"]== 20){
echo "<td>".$row["referencia"]."</td> \n";

echo "<td>".$row["of"]."</td> \n";

echo "<td>".$row["tiempo"]."</td> \n";

if ($row["tarea"]==50){
echo "<td>".$row["tiempo"]."</td> \n";
}
  #7 (permalink)  
Antiguo 15/09/2012, 03:15
 
Fecha de Ingreso: mayo-2006
Mensajes: 475
Antigüedad: 17 años, 11 meses
Puntos: 58
Respuesta: Datos de un campo como cabecera

Y si necesitas que te de:
Nombre Tarea 1 Tarea 2 Tarea 3
ya que dices que las tareas no cambian ¿por qué no has montado una tabla así?
  #8 (permalink)  
Antiguo 15/09/2012, 07:01
 
Fecha de Ingreso: mayo-2006
Mensajes: 475
Antigüedad: 17 años, 11 meses
Puntos: 58
Respuesta: Datos de un campo como cabecera

Así funciona y puedes añadir más nombres o tareas:
Código PHP:
Ver original
  1. <?php
  2. $tabla = mysql_query("SELECT * FROM tabla");
  3. $array=array();
  4. while($row_tabla = mysql_fetch_array($tabla)){//montar un array con el nombre como key
  5.     if(!array_key_exists($row_tabla['nombre'], $array)){
  6.         $array[$row_tabla['nombre']]=array();
  7.     }
  8.     if(!array_key_exists($row_tabla['tarea'], $array)){ //dentro de cada array otro array con la tarea como key
  9.         $array[$row_tabla['nombre']][$row_tabla['tarea']]=0;
  10.     }
  11.     $array[$row_tabla['nombre']][$row_tabla['tarea']]+=$row_tabla['tiempo'];//suma tiempos
  12. }
  13. ?>
  14. <table border="1">
  15. <tr><th>NOMBRES</th>
  16. <?php
  17. $cuenta_tareas=array();//array para guardar tareas
  18. $salida=''; //salida
  19. foreach($array as $k=>$v){//crear cabecera de tareas
  20.     foreach($v as $clave=>$valor){
  21.         if(!in_array($clave,$cuenta_tareas)){//si no ha salido
  22.             $cuenta_tareas[]=$clave;//la guardamos en el array y la mostramos
  23.             $salida.="<th>".$clave."</th>";
  24.         }
  25.     }
  26. }
  27. $salida.='</tr><tr>';//cerrar cabecera
  28. $cuenta_filas=0;//contador de filas
  29. foreach($array as $k=>$v){
  30.     $salida.= "<td>".$k."</td>";//muestra el nombre
  31.         for($i=0;$i<count($cuenta_tareas);$i++){//recorre el array de cabeceras
  32.             if(array_key_exists($cuenta_tareas[$i],$v)){//si existe en la posicion actual mostramos el resultado
  33.                     $salida.="<td>".$v[$cuenta_tareas[$i]]."</td>";
  34.                 }else{//si no existe ponemos celda vacía
  35.                     $salida.="<td>-</td>";
  36.                 }
  37.         }
  38.     if(count($array)>($cuenta_filas+1)){//cerrar filas si no es la última
  39.         $salida.='</tr><tr>';
  40.     }
  41.     $cuenta_filas++;
  42. }
  43. echo $salida;
  44. ?>
  45. </tr></table>

Etiquetas: tabla, campos, cabeceras
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:26.