Foros del Web » Programando para Internet » PHP »

Problemas con listado (producto cartesiano)

Estas en el tema de Problemas con listado (producto cartesiano) en el foro de PHP en Foros del Web. Hola buenas a todos, espero que no se asusten al ver tanto codigo jeje. Espero puedan ayudarme. Practicamente el problema lo tengo en el primer ...
  #1 (permalink)  
Antiguo 21/05/2015, 16:12
Avatar de nessy_ftv  
Fecha de Ingreso: mayo-2015
Ubicación: Madrid
Mensajes: 7
Antigüedad: 9 años, 6 meses
Puntos: 0
Problemas con listado (producto cartesiano)

Hola buenas a todos, espero que no se asusten al ver tanto codigo jeje.

Espero puedan ayudarme. Practicamente el problema lo tengo en el primer fragmento de codigo, que es una parte del segundo codigo que he adjuntado (el script de la vista).

El problema que tengo es que quiero que al listar los profesores aparezca el nombre solo una vez, como he hecho con los grupos, pero no consigo hacer lo mismo para este campo.

Pueden decirme que estoy haciendo mal? LLevo horas intentando sacarlo, pero no hay manera.

Muchas gracias y un saludo.

Olvide añadir la consulta que me devuelve todas las propuestas, es la siguiente:
Código:
SELECT p.cod_propuesta, p.fecha,p.reserva,p.transporte,p.entrada, p.tipo_periodo, p.creado_por, p.fecha_creacion, p.modificado_por, p.fecha_modificacion, d.nombre as destino,d.direccion,g.nombre as grupo, concat_ws(' ', u.nombre,u.apellidos) as profesor FROM destinos d 
      						INNER JOIN propuestas p ON d.cod_destino=p.destino 
      						INNER JOIN grupos_participantes_propuesta gpp ON p.cod_propuesta = gpp.cod_propuesta 
      						INNER JOIN profesores_participantes_propuesta ppp ON p.cod_propuesta=ppp.cod_propuesta 
      						INNER JOIN grupos g ON gpp.id_grupo=g.id_grupo 
      						INNER JOIN usuarios u ON ppp.usuario=u.usuario


Código PHP:
Ver original
  1. foreach ($propuestas as $unaPropuesta) {
  2.         if($unaPropuesta->devuelveCod_propuesta() == $ultimaPropuesta){//Seguimo en la misma propuesta que la anterior
  3.             if($unaPropuesta->devuelveGrupo() != $ultimoGrupo){
  4.                 $contenidoGrupos .= "{$unaPropuesta->devuelveGrupo()} <br>";
  5.                 $ultimoGrupo = $unaPropuesta->devuelveGrupo();
  6.             }
  7.             if($unaPropuesta->devuelveProfesor() != $ultimoProfesor){
  8.                 $contenidoProfesores .= "{$unaPropuesta->devuelveProfesor()} <br>";
  9.                 $ultimoProfesor = $unaPropuesta->devuelveProfesor();
  10.             }
  11.         }else{//Se ha producido un cambio de propuesta
  12.             if($ultimaPropuesta > 0){//No se trata de la primera iteracion
  13.                 $contenido = $contenido . $contenidoAntes . $contenidoGrupos . "</td>" . $contenidoProfesores . "</td>" . $contenidoDespues;
  14.                 $contenidoAntes = "";
  15.                 $contenidoGrupos = "";
  16.                 $contenidoProfesores = "";
  17.                 $contenidoDespues = "";
  18.             }
  19.             $ultimaPropuesta = $unaPropuesta->devuelveCod_propuesta();
  20.             $ultimoGrupo = $unaPropuesta->devuelveGrupo();
  21.             $ultimoProfesor = $unaPropuesta->devuelveProfesor();
  22.             $contenidoAntes = "
  23.        <tr>
  24.           <td>{$unaPropuesta->devuelveFecha()}</td>
  25.           <td>{$unaPropuesta->devuelveDestino()}</td>
  26.           <td>{$unaPropuesta->devuelveReserva()}</td>
  27.           <td>{$unaPropuesta->devuelveTransporte()}</td>
  28.           <td>{$unaPropuesta->devuelveEntrada()}</td>
  29.           ";
  30.           $contenidoGrupos = "<td>{$unaPropuesta->devuelveGrupo()} <br>";
  31.           $contenidoProfesores = "<td>{$unaPropuesta->devuelveProfesor()} <br>";
  32.           $contenidoDespues = "<td>{$unaPropuesta->devuelveFecha_creacion()}</td>
  33.           <td>{$unaPropuesta->devuelveCreado_por()}</td>
  34.           <td>{$unaPropuesta->devuelveFecha_modificacion()}</td>
  35.           <td>{$unaPropuesta->devuelveModificado_por()}</td>
  36.           <td><a href=\"javascript:confirmaBaja('{$unaPropuesta->devuelveCod_propuesta()}')\"> <img src='{$img}lapiz.jpg' width='25' height='25' /></a></td>
  37.           <td><a href=\"javascript:confirmaBaja('{$unaPropuesta->devuelveCod_propuesta()}')\"> <img src='{$img}aspa-roja.gif' width='25' height='25' /></a></td>
  38.        </tr>";
  39.         }
  40.     }
  41.     if($ultimaPropuesta > 0){//Se ha recibido alguna propuesta
  42.                 $contenido = $contenido . $contenidoAntes . $contenidoGrupos . "</td>" . $contenidoProfesores . "</td>" . $contenidoDespues;
  43.             }

Código PHP:
Ver original
  1. <?php
  2. require_once "modelo/Propuesta.php";
  3. require_once "conf/constantes.php";
  4.  
  5. class VistaListadoPropuesta {
  6.  
  7.   static function construye($propuestas) {
  8.  
  9.     $img = DIR_RAIZ_APP . '/img/';
  10.     $titulo = "Listado de Propuestas";
  11.     $contenido = "
  12.      <h1>$titulo</h1>
  13.      <table border='1' cellpadding='5' cellspacing='3'>
  14.       <tr>
  15.         <th>Fecha</th>
  16.         <th>Destino</th>
  17.         <th>Necesidad reserva</th>
  18.         <th>Necesidad de transporte</th>
  19.         <th>Necesidad de compra de entradas</th>
  20.         <th>Grupos</th>
  21.         <th>Profesores</th>
  22.         <th>Fecha de creación</th>
  23.         <th>Creado por</th>
  24.         <th>Fecha de modificacion</th>
  25.         <th>Modificado por</th>
  26.         <th>Modificar</th>
  27.         <th>Eliminar</th>
  28.       </tr>
  29.    ";
  30.     $ruta = DIR_RAIZ_APP . INDEX;
  31.     $ultimaPropuesta = 0;
  32.     $ultimoGrupo = "";
  33.     $ultimoProfesor = "";
  34.     $profesorAnterior = "";
  35.     $contenidoAntes = "";
  36.     $contenidoGrupos = "";
  37.     $contenidoProfesores = "";
  38.     $contenidoDespues = "";
  39.         foreach ($propuestas as $unaPropuesta) {
  40.         if($unaPropuesta->devuelveCod_propuesta() == $ultimaPropuesta){//Seguimo en la misma propuesta que la anterior
  41.             if($unaPropuesta->devuelveGrupo() != $ultimoGrupo){
  42.                 $contenidoGrupos .= "{$unaPropuesta->devuelveGrupo()} <br>";
  43.                 $ultimoGrupo = $unaPropuesta->devuelveGrupo();
  44.             }
  45.             if($unaPropuesta->devuelveProfesor() != $ultimoProfesor){
  46.                 $contenidoProfesores .= "{$unaPropuesta->devuelveProfesor()} <br>";
  47.                 $ultimoProfesor = $unaPropuesta->devuelveProfesor();
  48.             }
  49.         }else{//Se ha producido un cambio de propuesta
  50.             if($ultimaPropuesta > 0){//No se trata de la primera iteracion
  51.                 $contenido = $contenido . $contenidoAntes . $contenidoGrupos . "</td>" . $contenidoProfesores . "</td>" . $contenidoDespues;
  52.                 $contenidoAntes = "";
  53.                 $contenidoGrupos = "";
  54.                 $contenidoProfesores = "";
  55.                 $contenidoDespues = "";
  56.             }
  57.             $ultimaPropuesta = $unaPropuesta->devuelveCod_propuesta();
  58.             $ultimoGrupo = $unaPropuesta->devuelveGrupo();
  59.             $ultimoProfesor = $unaPropuesta->devuelveProfesor();
  60.             $contenidoAntes = "
  61.        <tr>
  62.           <td>{$unaPropuesta->devuelveFecha()}</td>
  63.           <td>{$unaPropuesta->devuelveDestino()}</td>
  64.           <td>{$unaPropuesta->devuelveReserva()}</td>
  65.           <td>{$unaPropuesta->devuelveTransporte()}</td>
  66.           <td>{$unaPropuesta->devuelveEntrada()}</td>
  67.           ";
  68.           $contenidoGrupos = "<td>{$unaPropuesta->devuelveGrupo()} <br>";
  69.           $contenidoProfesores = "<td>{$unaPropuesta->devuelveProfesor()} <br>";
  70.           $contenidoDespues = "<td>{$unaPropuesta->devuelveFecha_creacion()}</td>
  71.           <td>{$unaPropuesta->devuelveCreado_por()}</td>
  72.           <td>{$unaPropuesta->devuelveFecha_modificacion()}</td>
  73.           <td>{$unaPropuesta->devuelveModificado_por()}</td>
  74.           <td><a href=\"javascript:confirmaBaja('{$unaPropuesta->devuelveCod_propuesta()}')\"> <img src='{$img}lapiz.jpg' width='25' height='25' /></a></td>
  75.           <td><a href=\"javascript:confirmaBaja('{$unaPropuesta->devuelveCod_propuesta()}')\"> <img src='{$img}aspa-roja.gif' width='25' height='25' /></a></td>
  76.        </tr>";
  77.         }
  78.     }
  79.     if($ultimaPropuesta > 0){//Se ha recibido alguna propuesta
  80.                 $contenido = $contenido . $contenidoAntes . $contenidoGrupos . "</td>" . $contenidoProfesores . "</td>" . $contenidoDespues;
  81.             }
  82.     $contenido .= "
  83.       </table>
  84.         <script>
  85.             function confirmaBaja(propuesta) {
  86.                 respuesta = confirm('¿Está seguro de querer eliminar la propuesta?');
  87.                 if (respuesta)
  88.                     document.location.href = '{$ruta}propuesta/baja_propuesta?propuesta=' + propuesta;
  89.                 else
  90.                     alert('No se eliminará la propuesta');
  91.             }
  92.         </script>
  93.       <br />
  94.       ";
  95.     return $contenido;
  96.   }
  97. }
  98. ?>

Última edición por nessy_ftv; 22/05/2015 a las 00:29

Etiquetas: lista, listado, producto, 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 12:54.