Hola:
Queria comentar acerca del script, ya que me parece, simple y útil (a menudo la solución mas sencilla es la mejor - filosofia Unix -); pero lo que no me parece es que a propósito pongan el còdigo con errores, simplemente para que otros se den de cabezazos tratando de ejecutarlo correctamente. Creo que eso es arrogante y de una prepotencia intelectual poco honesta y detestable. Si de verdad quieren aportar; pues aporten como caballeros y con la fidelidad que la situaciòn lo amerita.
Aca dejo el codigo corregido, que tan gentilmente shift dejò a medias.
paginator.inc.php
Código PHP:
<?php
if(empty($_pagi_sql)){
die("<b>Error : </b>No se ha definido la variable \$_pagi_sql");
}
if(empty($_pagi_cuantos)){
$_pagi_cuantos = 20;
}
if(!isset($_pagi_mostrar_errores)){
$_pagi_mostrar_errores = true;
}
if(!isset($_pagi_conteo_alternativo)){
$_pagi_conteo_alternativo = false;
}
if(!isset($_pagi_separador)){
$_pagi_separador = " | ";
}
if(isset($_pagi_nav_estilo)){
$_pagi_nav_estilo_mod = "class=\"$_pagi_nav_estilo\"";
}else{
$_pagi_nav_estilo_mod = "";
}
if(!isset($_pagi_nav_anterior)){
$_pagi_nav_anterior = "« Anterior";
}
if(!isset($_pagi_nav_siguiente)){
$_pagi_nav_siguiente = "Siguiente »";
}
if(!isset($_pagi_nav_primera)){
$_pagi_nav_primera = "«« Primera";
}
if(!isset($_pagi_nav_ultima)){
$_pagi_nav_ultima = "Última »»";
}
if (empty($_GET['_pagi_pg'])){
$_pagi_actual = 1;
}else{
$_pagi_actual = $_GET['_pagi_pg'];
}
if($_pagi_conteo_alternativo == false){
$con = pg_connect("host=localhost port=5432 user=postgres password=123123 dbname=mibase");
$_pagi_sqlConta = "SELECT COUNT(*) as a FROM (".$_pagi_sql.") as f";
$_pa2 =pg_query($con,$_pagi_sqlConta);
$_pagi_result2 = pg_result($_pa2,"0","a");
if($_pagi_result2 == false && $_pagi_mostrar_errores == true){
die (" parra Error en la consulta de conteo de registros: $_pagi_sqlConta. // xxxxxxxxxxx$_pagi_result2xxxxxx postgres dijo: <b>".pg_result_error($_pa2)."</b>");
}
echo"Cantidad de registros ".$_pagi_result2;
$_pagi_totalReg=pg_result($_pa2,"0","a");
echo"\ntotal de registros".$_pagi_totalReg;
}else{
$_pagi_result3=pg_query($con,$_pagi_sql);
if($_pagi_result3 == false && $_pagi_mostrar_errores == true){
die (" Error en la consulta de conteo alternativo de registros: $_pagi_sql. eche dijo: <b>".pg_error($con)."</b>");
}
$_pagi_totalReg=pg_numrows($_pagi_result3);
}
$_pagi_totalPags = ceil($_pagi_totalReg / $_pagi_cuantos);
$_pagi_enlace = $_SERVER['PHP_SELF'];
$_pagi_query_string = "?";
if(!isset($_pagi_propagar)){
if (isset($_GET['_pagi_pg'])) unset($_GET['_pagi_pg']);
$_pagi_propagar = array_keys($_GET);
}elseif(!is_array($_pagi_propagar)){
die("<b>Error Paginator : </b>La variable \$_pagi_propagar debe ser un array");
}
foreach($_pagi_propagar as $var){
if(isset($GLOBALS[$var])){
$_pagi_query_string.= $var."=".$GLOBALS[$var]."&";
}elseif(isset($_REQUEST[$var])){
$_pagi_query_string.= $var."=".$_REQUEST[$var]."&";
}
}
$_pagi_enlace .= $_pagi_query_string;
$_pagi_navegacion_temporal = array();
if ($_pagi_actual != 1){
$_pagi_url = 1;
$_pagi_navegacion_temporal[] = "<a ".$_pagi_nav_estilo_mod." href='".$_pagi_enlace."_pagi_pg=".$_pagi_url."'>$_ pagi_nav_primera</a>";
$_pagi_url = $_pagi_actual - 1;
$_pagi_navegacion_temporal[] = "<a ".$_pagi_nav_estilo_mod." href='".$_pagi_enlace."_pagi_pg=".$_pagi_url."'>$_ pagi_nav_anterior</a>";
}
if(!isset($_pagi_nav_num_enlaces)){
$_pagi_nav_desde = 1;
$_pagi_nav_hasta = $_pagi_totalPags;
}else{
$_pagi_nav_intervalo = ceil($_pagi_nav_num_enlaces/2) - 1;
$_pagi_nav_desde = $_pagi_actual - $_pagi_nav_intervalo;
$_pagi_nav_hasta = $_pagi_actual + $_pagi_nav_intervalo;
if($_pagi_nav_desde < 1){
$_pagi_nav_hasta -= ($_pagi_nav_desde - 1);
$_pagi_nav_desde = 1;
}
if($_pagi_nav_hasta > $_pagi_totalPags){
$_pagi_nav_desde -= ($_pagi_nav_hasta - $_pagi_totalPags);
$_pagi_nav_hasta = $_pagi_totalPags;
if($_pagi_nav_desde < 1){
$_pagi_nav_desde = 1;
}
}
}
for ($_pagi_i = $_pagi_nav_desde; $_pagi_i<=$_pagi_nav_hasta; $_pagi_i++){
if ($_pagi_i == $_pagi_actual) {
$_pagi_navegacion_temporal[] = "<span ".$_pagi_nav_estilo_mod.">$_pagi_i</span>";
}else{
$_pagi_navegacion_temporal[] = "<a ".$_pagi_nav_estilo_mod." href='".$_pagi_enlace."_pagi_pg=".$_pagi_i."'>".$_pagi_i."</a>";
}
}
if ($_pagi_actual < $_pagi_totalPags){
$_pagi_navegacion_temporal[] = "<a ".$_pagi_nav_estilo_mod." href='".$_pagi_enlace."_pagi_pg=".$_pagi_url."'>$_ pagi_nav_siguiente</a>";
$_pagi_url = $_pagi_totalPags;
$_pagi_navegacion_temporal[] = "<a ".$_pagi_nav_estilo_mod." href='".$_pagi_enlace."_pagi_pg=".$_pagi_url."'>$_ pagi_nav_ultima</a>";
}
$_pagi_navegacion = implode($_pagi_separador, $_pagi_navegacion_temporal);
$_pagi_inicial = ($_pagi_actual-1) * $_pagi_cuantos;
$_pagi_sqlLim = $_pagi_sql." LIMIT $_pagi_cuantos OFFSET $_pagi_inicial";
$_pagi_result = pg_query($_pagi_sqlLim);
echo $_pagi_result;
if($_pagi_result == false && $_pagi_mostrar_errores == true){
die ("Error en la consulta limitada: $_pagi_sqlLim. Mysql dijo: <b>".pg_error($con)."</b>");
}
$_pagi_desde = $_pagi_inicial + 1;
$_pagi_hasta = $_pagi_inicial + $_pagi_cuantos;
if($_pagi_hasta > $_pagi_totalReg){
$_pagi_hasta = $_pagi_totalReg;
}
$_pagi_info = "desde el $_pagi_desde hasta el $_pagi_hasta de un total de $_pagi_totalReg";
?>
prueba.php
Código PHP:
<?php
$con ="host=localhost port=5432 user=postgres password=123123 dbname=mibase";
$conecta=pg_connect($con);
//Sentencia sql (sin limit)
$_pagi_sql = "SELECT * FROM socios";
//cantidad de resultados por página (opcional, por defecto 20)
$_pagi_cuantos = 8;
$_pagi_nav_num_enlaces = 1;
include("paginator.inc.php");
while($row = pg_fetch_array($_pagi_result)){
echo $row['nombresocio']. $row['apellido1socio']. $row['apellido2socio']."<br />";
}
//Incluimos la barra de navegación
echo"<p>".$_pagi_navegacion."</p>";
?>