Quiero paginar los resultados por grupos y fecha, que quiero decir con esto... pues bien, tengo una tabla llamada jornadas, en ella tengo el campo tipo,fecha,nombre. Me gustaría paginar los resultados de la siguiente forma: lo primero que saldría sería los del tipo y fecha que estuviesen más cercano a la fecha actual, osea por ejemplo hoy, saldria primero los resultados del dia 7 hasta el mayor del mismo tipo. No sé si me explico...
Esto sería los resultados de la tabla:
Nombre
Jornada 1
Tipo
1
Fecha
07-08-2011
Nombre
Jornada 1
Tipo
1
Fecha
10-08-2011
------
Nombre
Jornada 2
Tipo
2
Fecha
09-09-2011
Bien, aquí el script debería mostrar en la página 1, los resultados del tipo uno ya que son los más proximos a la fecha actual, en la página dos debería mostrar los resultados del tipo 2, como solo hay uno, pues que muestre solo ese... el caso es que el script lo he echo... el problema es cuando pulsas en anterior o siguiente, el siguiente te muestra los resultados como es, cuando le das a anterior no funciona correctamente.
Código:
El problema es que cuando le das a siguiente, está bien, en el enlace de siguiente te da el id de la jornda correcta, cuando le das a anterior siempre te da el id de la jornada 1... que no es la menor.<?php global $wpdb; $enlacesiguiente=''; $enlaceanterior=''; if(isset($_GET['jornada'])) { $jornada = intval($_GET['jornada']); } else{ $jornada = 0; } if($jornada == 0){ $hoy=date('Y-m-d'); $row = $wpdb->get_row("SELECT jornada FROM ".$wpdb->prefix."_partidos WHERE fecha >= '$hoy' GROUP BY jornada LIMIT 1"); if($row->jornada > 0) { $jornadasig = $wpdb->get_row("SELECT jornada FROM ".$wpdb->prefix."_partidos WHERE fecha >= '$hoy' and jornada != '".$row->jornada."' GROUP BY jornada LIMIT 1"); $jornadaant = $wpdb->get_row("SELECT jornada FROM ".$wpdb->prefix."_partidos WHERE fecha < '$hoy' and jornada != '".$row->jornada."' GROUP BY jornada LIMIT 1"); if($jornadasig->jornada > 0) { $siguiente = true; $enlacesiguiente = $jornadasig->jornada; } if(@$jornadaant->jornada > 0) { $anterior = true; $enlaceanterior = $jornadaant->jornada; } } $fechadb=$hoy; $jornadadb=$row->jornada; }else{ $jornadactual = intval($_GET['jornada']); $actualdia = $wpdb->get_row("SELECT fecha FROM ".$wpdb->prefix."_partidos WHERE jornada='".$jornadactual."' GROUP BY jornada LIMIT 1"); if($jornadactual > 0) { $jornadasig = $wpdb->get_row("SELECT jornada FROM ".$wpdb->prefix."_partidos WHERE fecha >= '".$actualdia->fecha."' and jornada!='".$jornadactual."' GROUP BY jornada LIMIT 1"); $jornadaant = $wpdb->get_row("SELECT jornada FROM ".$wpdb->prefix."_partidos WHERE fecha < '".$actualdia->fecha."' and jornada!='".$jornadactual."' GROUP BY jornada LIMIT 1"); if(@$jornadasig->jornada > 0) { $siguiente = true; $enlacesiguiente = $jornadasig->jornada; } if($jornadaant->jornada > 0) { $anterior = true; $enlaceanterior = $jornadaant->jornada; } } $fechadb=$actualdia->fecha; $jornadadb=$jornadactual; } ?> <?php if(isset($anterior)){ ?> <a href="admin.php?page=Jornadas&jornada=<?php echo $enlaceanterior; ?>">Anterior jornada</a> <?php } ?> <?php if(isset($siguiente)){ ?> <a href="admin.php?page=Jornadas&jornada=<?php echo $enlacesiguiente; ?>">Siguiente jornada</a> <?php } ?> <?php echo listado_partidos(2,'','',id_temp_activa()," and jornada='".$jornadadb."' and fecha >= '".$fechadb."'"); ?> la función contiene esto: <?php if($tipo==2){ $hoy=date('Y-m-d'); $row = $wpdb->get_row("SELECT jornada FROM ".$wpdb->prefix."_partidos WHERE fecha >= '$hoy' GROUP BY jornada LIMIT 1"); $partidos = $wpdb->get_results("SELECT id,equipo_l,equipo_v,fecha,hora,hora_conf,competicion,jornada,tipo,id_ant,temporada FROM ".$wpdb->prefix."_partidos WHERE temporada='".intval($temporada)."'".$ops_db." ORDER BY fecha ASC"); $listado=''; foreach ($partidos as $partido) { if($partido->hora_conf==1){$txt_cnf='Confirmada';}else{$txt_cnf='Sin confirmar';} $listado.=' <tr> <td class="post-title page-title column-title row-title"> <strong>'.nombre_jornada_by_id($partido->jornada).'</strong> <p class="f_left clr">Día: <input type="text" class="f_right" value="'.$partido->fecha.'" /></p> <p class="f_left clr">Hora: <input type="text" class="f_right" value="'.$partido->hora.'" /></p> <p class="clr"><strong>'.$txt_cnf.'</strong></p> </td> <td class="author column-author"> <img src="'.escudo_equipo($partido->equipo_l).'" width="30" height="30" style="border:none;background:none;" /> <p class="clr"><strong>Local</strong> '.nombre_equipo_by_id($partido->equipo_l).'</p> </td> <td class="categories column-categories"> <img src="'.escudo_equipo($partido->equipo_v).'" width="30" height="30" style="border:none;background:none;" /> <p class="clr"><strong>Visitante</strong> '.nombre_equipo_by_id($partido->equipo_v).'</p> </td> </tr> '; } return $listado; } ?>
No veo el fallo por ningún sitio...