Foros del Web » Programando para Internet » PHP »

Ayuda con paginador utilizando PEAR

Estas en el tema de Ayuda con paginador utilizando PEAR en el foro de PHP en Foros del Web. Hola foreros estoy probando este codigo de manera local uso Appserv y BD postgres en WinXP De antemano les dire que ya instale el PEAR ...
  #1 (permalink)  
Antiguo 05/06/2009, 11:19
Avatar de Enishy  
Fecha de Ingreso: septiembre-2007
Mensajes: 121
Antigüedad: 16 años, 6 meses
Puntos: 1
Ayuda con paginador utilizando PEAR

Hola foreros estoy probando este codigo de manera local uso Appserv y BD postgres en WinXP

De antemano les dire que ya instale el PEAR y esta funcionando mi Pager, bueno de cierta forma funciona mi codigo de paginación .

Cuando ejecuto mi codigo mi tabla aparece vacia y mis link abajo...luego al pasar a la siguiente pagina [2] ya aparecen los primeros 10 datos de mi tabla... al pasar a la siguiente pagina [3] aparecen los otros 10 datos, pero debajo de los 10 anteriores; es decir aparecen 20 registros en la tabla, y esto es incorrecto pues los resultados se deben mostrar de 10 en 10 segun vaya navegando por los link espero haberme explicado bien aqui esta el codigo que estoy utilizando

Código PHP:
<?php
require_once ( 'Pager/Pager.php' ) ; 
include(
'conexion.php');

/* First we need to get the total rows in the table */
$res=pg_exec($DB,"SELECT count(*) AS total FROM detalle_operacion");
$row pg_fetch_array($res);
 
/* Total number of rows in the logs table */
$totalItems $row['total'];
 
/* Set some options for the Pager */
$pager_options = array(
'mode'       => 'Sliding',   // Sliding or Jumping mode. See below.
'perPage'    => 10,   // Total rows to show per page
'delta'      => 4,   // See below
'spacesBeforeSeparator' => 1,
'nextImg'    => "<img src='../../images/action_2rightarrow.png' width='30' height='30' border='0' align='absmiddle' />",
'prevImg'    => "<img src='../../images/action_2leftarrow.png'  width='30' height='30' border='0' align='absmiddle' />",
'totalItems' => $totalItems,
);
 
/* Initialize the Pager class with the above options */
$pager Pager::factory($pager_options);
 
/* The following code will retreive the result using the pager options */
 
/* The function below will get the page offsets to be used with
the database query. For e.g if we are on the third page then the
$from variable will have the value of '21' (we are showing 10 items per 
page, remember) and the $to variable will have the value of '30'.
*/
list($from$to) = $pager->getOffsetByPageId();
/* The MySQL 'LIMIT' clause index starts from '0', 
    so decrease the $from by 1 */
$from $from 1;
 
/* The number of rows to get per query */
$perPage $pager_options['perPage'];
 
$result pg_exec($DB,"SELECT opr.descripcion_operacion, det.hora_detalle, det.fecha_detalle, det.descripcion_detalle
FROM Usuario AS usr, Detalle_Operacion AS det, Operacion AS opr
WHERE opr.codigo_operacion = det.codigo_operacion
AND usr.codigo_usuario = det.codigo_usuario  LIMIT $from OFFSET $perPage"
);

echo
"
<html>
<head>
<title> :: Bitacora Resultado:: </title>
<link rel='shortcut icon' href='../../images/favicon.ico'>
<link href='../../styles/style.css' rel='stylesheet' type='text/css'>
</head>
<body>
<table width='700' border='1' cellpadding='3' cellspacing='1' align='center'> 
                                 <tr>
                                    <td class='navbar'><strong>Descripci&oacute;n de la Operaci&oacute;n</strong></td>
                                    <td class='navbar'><strong>Hora de Operaci&oacute;n</strong></td>
                                    <td class='navbar'><strong>Fecha de Operaci&oacute;n</strong></td>
                                    <td class='navbar'><strong>Detalle de Operaci&oacute;n</strong></td>
                                </tr>
"

while(
$data pg_fetch_array($result)){
echo
"
                                <tr>
                                    <td>$data[descripcion_operacion]</td>
                                    <td>$data[hora_detalle]</td>
                                    <td>$data[fecha_detalle]</td>
                                    <td>$data[descripcion_detalle]</td>
                                </tr>"
;
                                    }
echo
"
                                <table border='1' cellpadding='3' cellspacing='1' align='center'>
                                <tr>
                                    <td>$pager->links<td>
                                </tr>
                                </table>
</table>
</body>
</html>"
;
?>
  #2 (permalink)  
Antiguo 06/06/2009, 11:28
Avatar de Enishy  
Fecha de Ingreso: septiembre-2007
Mensajes: 121
Antigüedad: 16 años, 6 meses
Puntos: 1
Respuesta: Ayuda con paginador utilizando PEAR

Hola foreros aun no resuelvo este problema...porfa ayudenme ... no se que estoy haciendo mal pues la paginación no muestra los resultados de 10 en 10 si no que muestra los resultados los 1eros 10 y luego los sgtes 10 debajo del anterior....e estado buscando otros paginadores pero no me funcionan pues yo uso BD postgres los e modificado y nada .... lo que no pasa con este modo que estoy intentando hacer que utilizando PEAR
  #3 (permalink)  
Antiguo 10/06/2009, 15:42
Avatar de Enishy  
Fecha de Ingreso: septiembre-2007
Mensajes: 121
Antigüedad: 16 años, 6 meses
Puntos: 1
Respuesta: Ayuda con paginador utilizando PEAR

Hola foreros encontre la solución a este paginador usando PEAR

El cambio se hace en la consulta, es decir yo tenia esto:

Código PHP:
$result pg_exec($DB,"SELECT opr.descripcion_operacion, det.hora_detalle, det.fecha_detalle, det.descripcion_detalle
FROM Usuario AS usr, Detalle_Operacion AS det, Operacion AS opr
WHERE opr.codigo_operacion = det.codigo_operacion
AND usr.codigo_usuario = det.codigo_usuario  LIMIT $from OFFSET $perPage"
); 
cambienlo por esto, no ten la parte de LIMIT y OFFSET alli esta el cambio

Código PHP:
$result pg_exec($DB,"SELECT opr.descripcion_operacion, det.hora_detalle, det.fecha_detalle, det.descripcion_detalle
FROM Usuario AS usr, Detalle_Operacion AS det, Operacion AS opr
WHERE opr.codigo_operacion = det.codigo_operacion
AND usr.codigo_usuario = det.codigo_usuario  LIMIT $perPage OFFSET $from"
); 
PEAR PHP es la extensión y aplicación de repositorios estándar, estructurado, mantenido paquetes de código para tareas comunes como la validación de datos, el acceso a servidores de bases de datos, procesamiento de pagos, utilizando servicios web, procesamiento de imágenes, y leer y escribir archivos. Instalación, actualización y utilización de los paquetes PEAR es fácil, y ahora son los componentes principales instalados con el estándar de instalación de PHP. (fuente pear.php.net)

El ejemplo lo saque de esta pagina http://www.codediesel.com/php/simple-pagination-in-php/

Bueno lo que que da es instalar PEAR en nuestra maquina lo que no es dificil pues Appserv a partir de la version 5.x viene con el pear
  #4 (permalink)  
Antiguo 10/06/2009, 16:00
(Desactivado)
 
Fecha de Ingreso: diciembre-2008
Mensajes: 32
Antigüedad: 15 años, 3 meses
Puntos: 2
Respuesta: Ayuda con paginador utilizando PEAR

gracias por el monologo, aprendi un poco tambien
  #5 (permalink)  
Antiguo 10/06/2009, 17:33
Avatar de aldo1982  
Fecha de Ingreso: noviembre-2004
Ubicación: Santa Fe (Argentina) Colon F.C
Mensajes: 1.362
Antigüedad: 19 años, 4 meses
Puntos: 6
De acuerdo Respuesta: Ayuda con paginador utilizando PEAR

buen monologo jejeje nunca usé PEAR ... que ventajas tiene ?

salu2
__________________
LA MUERTE ESTÁ TAN SEGURA DE VENCER QUE NOS DA TODA UNA VIDA DE VENTAJA
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:53.