Foros del Web » Programando para Internet » PHP »

Problema al paginar tabla con clase

Estas en el tema de Problema al paginar tabla con clase en el foro de PHP en Foros del Web. Hola a todos encontré esta clase para paginar una tabla desde una base de datos mysql la clase funciona casi a la perfección acepto por ...
  #1 (permalink)  
Antiguo 15/08/2008, 21:22
 
Fecha de Ingreso: septiembre-2007
Mensajes: 9
Antigüedad: 16 años, 7 meses
Puntos: 0
Problema al paginar tabla con clase

Hola a todos encontré esta clase para paginar una tabla desde una base de datos mysql la clase funciona casi a la perfección acepto por un detalle, no se porque no avanza a la siguiente pagina, gracias a quienes puedan ayudarme.


Esta es la clase

Código PHP:
<?php

    
class queryList {

        function 
queryList($sql$link$page$rowsPerPage$pageLimit) {

            
// check the numbers of pages
            
$result        mysql_query($sql);
            
$totalRows    mysql_num_rows($result);
            
$totalPages ceil($totalRows $rowsPerPage);


            
// verify the given values
            
$page $page*1
            
$rowsPerPage $rowsPerPage*1
            
$pageLimit $pageLimit*1
            if(!
is_int($rowsPerPage) || $rowsPerPage 1) { $rowsPerPage 10; }
            if(!
is_int($pageLimit)   || $pageLimit   1) { $pageLimit   10; }
            if(
$page $totalPages) { $page $totalPages; }
            if(!
is_int($page) || $page 1) { $page 1; }


            
// build the starting values
            
if($totalPages $pageLimit ) { $value $pageLimit; } 
                else { 
$value $totalPages; }
            if(
$page $pageLimit) { $i $page $pageLimit$value $pageLimit+$i; }
            
            
$pages "";
            
// section for Previous Record
            
if($page 1){
                
$pages .= '&nbsp;<b>[ <a href='.$link.'&page='.($page-1).'>anterior</a> ] &nbsp;</b>';
            }


            
// build the Pages Browser
            
while (@$i $value){
                @
$i++;
                if (
$i == $page){
                    
$pages .= '<b>['.$i.']</b>&nbsp;';
                } else { 
                    if(
$i <= $totalPages) { 
                        
$pages .= '<a href='.$link.'&page='.$i.'>'.$i.'</a>'
                    }
                }
            }


            
// section for Next Record
            
if($i <= $totalPages){
                if(
$totalPages != $page){
                    
$pages .= '&nbsp;<b>[ <a href='.$link.'&page='.($page+1).'>siguiente</a> ]</b>';
                }
            }


            
// make the return values
            
$this->result $pages;
            
$this->start  = (($page-1) * $rowsPerPage) + 1;
            
$this->total  $totalRows;
            
$this->pages  $totalPages;
            
$this->sql      $sql.' LIMIT '.($page-1)*$rowsPerPage.','.$rowsPerPage;
            
            
$stop "";
            if(
$page==$totalPages) { 
        
$this->stop = ($page-1)*$rowsPerPage+($totalRows-(($page-1)*$rowsPerPage)); 
      } else { 
        
$this->stop $page $rowsPerPage
      }

        } 
// end of query()
        
    
// end of Class


?>

aqui el uso y resutado

Código PHP:
<?php
include 'db_config.php';
include 
'queryList.php';
$sql "SELECT * FROM tabla ORDER BY campo DESC";
$queryList = new queryList();
$queryList->queryList($sql'lista_contactos.php?', @$page1020);

//aqui se muestra el resultado
$result mysql_query ($queryList->sql);

?>

<table cellspacing="0" cellpadding="0" border="0" width="600px">
  <tr>
    <th>Id</th>
    <th>Nombres y apellidos</th>
    <th>Telefono</th>
    <th>Acciones</th>
  </tr>
  <?php
       
while ($fila mysql_fetch_assoc($result)) {
       
$nombre         $fila["nombre"];
       
$apellidos     $fila["apellidos"];
       
$email             $fila["email"];
       
$telefono       $fila["telefono"];         
        
?>
   <tr>
    <td><?php echo $nombre ?></td>
    <td><?php echo $apellidos ?></td>
    <td><?php echo $email?></td>
    <td><?php echo $telefono;?></td>
  </tr>
  <?php    ?>
</table>

<?php
if($queryList->pages 1) { 
    echo 
'Paginas ('$queryList->pages .') : ';  
    echo 
$queryList->result
}
echo 
"<br>";
if(
$queryList->total >= 1) { 
    echo 
'Archivos mostrados <font color=red>'$queryList->start .'</font> a <font color=red>'$queryList->stop .'</font> de <font color=red>'$queryList->total .'</font>'
}

?>
Como podrán ver todo parece estar bien, no se porque no avanza a la siguiente pagina.

Saludos.
  #2 (permalink)  
Antiguo 15/08/2008, 23:51
Avatar de emiliodeg  
Fecha de Ingreso: septiembre-2005
Ubicación: Córdoba
Mensajes: 1.830
Antigüedad: 18 años, 8 meses
Puntos: 55
Respuesta: Problema al paginar tabla con clase

$queryList->queryList($sql, 'lista_contactos.php?', @$page, 10, 20);

cambialo por $_GET['page']; o la variable que este usando para mandar el numero de pagina
__________________
Degiovanni Emilio
developtus.com
  #3 (permalink)  
Antiguo 16/08/2008, 10:07
 
Fecha de Ingreso: septiembre-2007
Mensajes: 9
Antigüedad: 16 años, 7 meses
Puntos: 0
Respuesta: Problema al paginar tabla con clase

Asunto resuelto, Gracias por la ayuda emiliodeg, el problema estaba ahi.
  #4 (permalink)  
Antiguo 16/08/2008, 10:28
 
Fecha de Ingreso: septiembre-2007
Mensajes: 9
Antigüedad: 16 años, 7 meses
Puntos: 0
Respuesta: Problema al paginar tabla con clase

Bueno una vez más necesito de vuestra ayuda, el problema que surgió ahora es que no funciona la navegación al hacer clic en los números de página, no obstante si funciona con los link siguiente y anterior.

El problema esta es aquí [anterior] [1] 2 3 4… [Siguiente]

Gracias a quien pueda ayudarme.
  #5 (permalink)  
Antiguo 17/08/2008, 23:05
 
Fecha de Ingreso: septiembre-2007
Mensajes: 9
Antigüedad: 16 años, 7 meses
Puntos: 0
Problema al paginar tabla con clase

¡Hola aun no pude solucionar en problema nuevo que surgió al hacer clic en los números de página. Por a favor que alguien me ayude gracias es muy importante!.

El problema esta es aquí [anterior] [1] 2 3 4… [Siguiente]

Saludos.
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 03:08.