Foros del Web » Programando para Internet » PHP »

Paginar resultados por grupo y fecha

Estas en el tema de Paginar resultados por grupo y fecha en el foro de PHP en Foros del Web. Hola, Quiero paginar los resultados por grupos y fecha, que quiero decir con esto... pues bien, tengo una tabla llamada jornadas, en ella tengo el ...
  #1 (permalink)  
Antiguo 07/08/2011, 07:41
 
Fecha de Ingreso: febrero-2011
Mensajes: 37
Antigüedad: 13 años, 2 meses
Puntos: 2
Paginar resultados por grupo y fecha

Hola,

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:
<?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;
}
?>
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.

No veo el fallo por ningún sitio...
  #2 (permalink)  
Antiguo 07/08/2011, 17:44
 
Fecha de Ingreso: febrero-2011
Mensajes: 37
Antigüedad: 13 años, 2 meses
Puntos: 2
Respuesta: Paginar resultados por grupo y fecha

Nadie puede echarme una mano? llevo con esto una semana y nada...

A ver amplio la información: el problema con el código es que una vez llega a la jornada 3, no va el "anterior" ya que siempre da la jornada 1, xk la fecha es menor, de lo que se trata es de como hacer para que busque la fecha menor pero buscando el mes anterior. osea siempre busque el mes anterior mas próximo... quién dice mes dice la fecha entera...

edito:

lo he solucionado con un order by fecha DESC en la consulta de la jornada anterior... lo que no sé es si puede dar conflicto alguna vez...

Última edición por danicss; 07/08/2011 a las 18:01

Etiquetas: fecha, grupo, paginar, resultados, 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 13:45.