Foros del Web » Programando para Internet » PHP »

problema en la paginación de mi consulta

Estas en el tema de problema en la paginación de mi consulta en el foro de PHP en Foros del Web. tengo el siguiente codigo que me carca dos warning pero no se cual es el problema estos son los warning: *Warning: mysql_num_rows(): supplied argument is ...
  #1 (permalink)  
Antiguo 29/03/2008, 14:50
Avatar de bandolera_triste  
Fecha de Ingreso: noviembre-2007
Mensajes: 136
Antigüedad: 16 años, 4 meses
Puntos: 0
problema en la paginación de mi consulta

tengo el siguiente codigo que me carca dos warning pero no se cual es el problema
estos son los warning:
*Warning: mysql_num_rows(): supplied argument is not a valid MySQL result resource in C:\xampp\htdocs\maravillas\playasresultado.php on line 84
*Warning: Division by zero in C:\xampp\htdocs\maravillas\playasresultado.php on line 86

me podrian ayudar?
<?php
$pagina = $_GET["pagina"];
include("conexion.php");
$registros = 3;
if (!$pagina) {
$inicio = 0;
$pagina = 1;
}
else {
$inicio = ($pagina - 1) * $registros;
}
//variables tomadas de los criterios para buscar viviendas
$tipo = $_GET['tipo'];
$playa = $_GET['playa'];
$categoria = "PLAYA";
$precioinicial =$_GET['precioinicial'];
$preciofinal =$_GET['preciofinal'];
$disponible ="SI";
$nh =$_GET['nh'];
$coches =$_GET['coches'];
$operacion =$_GET['operacion'];

$query = "SELECT vivienda.id_v, vivienda.tipo_v, vivienda.precio_d, vivienda.operacion, imagen.img1 from vivienda left join detalle_vivienda on detalle_vivienda.id_v = vivienda.id_v left join imagen on imagen.id_v = vivienda.id_v WHERE 1 LIMIT $inicio,$registros";
if ($playa !== "opc")
{$query.= " AND vivienda.id_v like '{$playa}%'";}
if ($tipo !== "opc")
{$query.= " AND vivienda.tipo_v = '{$tipo}'";}
if ($categoria !== "opc")
{$query.= " AND vivienda.categoria = '{$categoria}'";}
if (($precioinicial !== "opc")&&($preciofinal == "opc"))
{$query.= " AND vivienda.precio_d >= '{$precioinicial}'";}
if (($precioinicial == "opc")&&($preciofinal !== "opc"))
{$query.= " AND vivienda.precio_d <= '{$preciofinal}'";}
if ($disponible !== "opc")
{$query.= " AND vivienda.disponible = '{$disponible}'";}
if ($operacion !== "opc")
{$query.= " AND vivienda.operacion like '%{$operacion}%'";}
if ($nh !== "opc")
{$query.= " AND detalle_vivienda.n_habitacion = '{$nh}'";}
if ($coches !== "opc")
{$query.= " AND detalle_vivienda.est = '{$coches}'";}

$res=mysql_query($query);
$total_registros = mysql_num_rows($res);
$res=mysql_query($query);
$total_paginas = ceil($total_registros/$res);
?>

y en una tabla pongo el resultado pero nada no sale nada
<table border=1 align=center width=100%>
<tr>
<th BGCOLOR = #FFFF99><font color="#000033" size="5">FOTOS</font></th>
<th BGCOLOR = #FFFF99><font color="#000033" size="5">DETALLES</font></th>
</tr>
<?

if($total_registros) {
while (list($id_v,$tipo_v,$precio_d,$operacion,$img1) = mysql_fetch_array($res))
{
echo "
<tr>
<td align='center'>
<img src='$img1' name='slideshow' high='250' width='230'>&nbsp;&nbsp;
</td>
<td><font color='#000000' size='4'>
<b>CLAVE:</b>$id_v<br>
<b>TIPO DE VIVIENDA:</b>$tipo_v<br>
<B>PRECIO X NOCHE:</B>$precio_d<BR>
<B>OPERACION:</B>$operacion<BR>
<a href='verplayas.php?id_v=$id_v'><B>DA CLICK AQUI PARA VER DETALLES Y MÁS FOTOGRAFÍAS...</B></a><BR>
</font>
</td>
</tr>";
}//cierre del while

} else {
echo "<tr><td><center><font color='darkgray' size='4'>(sin resultados)</font></center></td></tr>
";

}

//paginación
mysql_free_result($resultados);

if($total_registros) {

echo "<center>";

if(($pagina - 1) > 0) {
echo "<a href='playasresultado.php?pagina=".($pagina-1)."'>< Anterior</a> ";
}

for ($i=1; $i<=$total_paginas; $i++){
if ($pagina == $i) {
echo "<b>".$pagina."</b> ";
} else {
echo "<a href='playasresultado.php?pagina=$i'>$i</a> ";
}
}

if(($pagina + 1)<=$total_paginas) {
echo " <a href='playasresultado.php?pagina=".($pagina+1)."'> Siguiente ></a>";
}

echo "</center>";

}
?>
</table>
<?php mysql_close($conex);?>
  #2 (permalink)  
Antiguo 29/03/2008, 15:18
okram
Invitado
 
Mensajes: n/a
Puntos:
Re: problema en la paginación de mi consulta

Qué intentas hacer aquí?

Código PHP:
$res=mysql_query($query);
$total_registros mysql_num_rows($res); 
$res=mysql_query($query);
$total_paginas ceil($total_registros/$res); 
Parece que tienes un error en la consulta. Prueba poniendo:

Código PHP:
$res=mysql_query($query) or die(mysql_error()); 
Para ver que error tienes.

Saludos,
  #3 (permalink)  
Antiguo 29/03/2008, 15:22
okram
Invitado
 
Mensajes: n/a
Puntos:
Re: problema en la paginación de mi consulta

Revisando mejor tu código doy con esto:

Código PHP:
$query "SELECT vivienda.id_v, vivienda.tipo_v, vivienda.precio_d, vivienda.operacion, imagen.img1 from vivienda left join detalle_vivienda on detalle_vivienda.id_v = vivienda.id_v left join imagen on imagen.id_v = vivienda.id_v WHERE 1 LIMIT $inicio,$registros";
if (
$playa !== "opc")
{
$query.= " AND vivienda.id_v like '{$playa}%'";}
if (
$tipo !== "opc")
{
$query.= " AND vivienda.tipo_v = '{$tipo}'";}
if (
$categoria !== "opc")
{
$query.= " AND vivienda.categoria = '{$categoria}'";}
if ((
$precioinicial !== "opc")&&($preciofinal == "opc"))
{
$query.= " AND vivienda.precio_d >= '{$precioinicial}'";}
if ((
$precioinicial == "opc")&&($preciofinal !== "opc")) 
{
$query.= " AND vivienda.precio_d <= '{$preciofinal}'";}
if (
$disponible !== "opc")
{
$query.= " AND vivienda.disponible = '{$disponible}'";}
if (
$operacion !== "opc")
{
$query.= " AND vivienda.operacion like '%{$operacion}%'";} 
if (
$nh !== "opc")
{
$query.= " AND detalle_vivienda.n_habitacion = '{$nh}'";}
if (
$coches !== "opc")
{
$query.= " AND detalle_vivienda.est = '{$coches}'";} 
Así estás dividiendo la claúsula WHERE metiendo el LIMIT adentro. Hazlo así:

Código PHP:
$query "SELECT vivienda.id_v, vivienda.tipo_v, vivienda.precio_d, vivienda.operacion, imagen.img1 from vivienda left join detalle_vivienda on detalle_vivienda.id_v = vivienda.id_v left join imagen on imagen.id_v = vivienda.id_v WHERE 1=1";

if (
$playa !== "opc")
{
$query.= " AND vivienda.id_v like '{$playa}%'";}
if (
$tipo !== "opc")
{
$query.= " AND vivienda.tipo_v = '{$tipo}'";}
if (
$categoria !== "opc")
{
$query.= " AND vivienda.categoria = '{$categoria}'";}
if ((
$precioinicial !== "opc")&&($preciofinal == "opc"))
{
$query.= " AND vivienda.precio_d >= '{$precioinicial}'";}
if ((
$precioinicial == "opc")&&($preciofinal !== "opc")) 
{
$query.= " AND vivienda.precio_d <= '{$preciofinal}'";}
if (
$disponible !== "opc")
{
$query.= " AND vivienda.disponible = '{$disponible}'";}
if (
$operacion !== "opc")
{
$query.= " AND vivienda.operacion like '%{$operacion}%'";} 
if (
$nh !== "opc")
{
$query.= " AND detalle_vivienda.n_habitacion = '{$nh}'";}
if (
$coches !== "opc")
{
$query.= " AND detalle_vivienda.est = '{$coches}'";}
 
$query.= " LIMIT $inicio,$registros"
Saludos,

Pd. Pero igual hay error en el código que te cité en el mensaje anterior, pues $res es el resultado de una consulta, no un número. Por lo tanto no puedes usarlo en una división.

Saludos,
  #4 (permalink)  
Antiguo 29/03/2008, 15:37
Avatar de bandolera_triste  
Fecha de Ingreso: noviembre-2007
Mensajes: 136
Antigüedad: 16 años, 4 meses
Puntos: 0
Re: problema en la paginación de mi consulta

Cita:
Pd. Pero igual hay error en el código que te cité en el mensaje anterior, pues $res es el resultado de una consulta, no un número. Por lo tanto no puedes usarlo en una división.

Saludos,
por eso hago dos veces el query, uno donde me da el numero de registros y otro donde muestro los registros, o a ke te refieres?
  #5 (permalink)  
Antiguo 29/03/2008, 17:10
okram
Invitado
 
Mensajes: n/a
Puntos:
Re: problema en la paginación de mi consulta

Código PHP:
$total_paginas ceil($total_registros/$res); 
// CReo que debe ser 
# $total_paginas = ceil($total_registros/$registros); 
Pero $res es lo que te devuelve la función mysql_query previa. Además, para calcular cuantos registros hay no es necesario que hagas una consulta adicional:

Código PHP:
$res mysql_query($query);
$total_registros mysql_num_rows($res);
 
// ...
 
while (list($id_v,$tipo_v,$precio_d,$operacion,$img1) = mysql_fetch_array($res))

Un saludo,
  #6 (permalink)  
Antiguo 29/03/2008, 17:51
 
Fecha de Ingreso: agosto-2004
Mensajes: 440
Antigüedad: 19 años, 8 meses
Puntos: 2
Re: problema en la paginación de mi consulta

espero este codigo te sirva

paginacion.php
Código PHP:
<?
//conecto con la base de datos 
$conn mysql_connect("localhost","root","contraseña");  
mysql_select_db("basededatos",$conn); 
$registros 2;

if (!
$pagina) { 
    
$inicio 0
    
$pagina 1

else { 
    
$inicio = ($pagina 1) * $registros


?>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
<title></title>
</head>
<body>
    <?

    $resultados1 
mysql_query("SELECT id FROM noticias ",$conn);
    
$total_registros mysql_num_rows($resultados1); 
    
$resultados mysql_query("SELECT * FROM noticias LIMIT $inicio, $registros",$conn);    
    
$total_paginas ceil($total_registros $registros);                       

     
$num_filas mysql_num_rows($resultados1);
     if(
$num_filas!=0){
    
?>
        <table width="100%" border="0" align="center" cellpadding="0" cellspacing="0" bordercolor="#111111" id="AutoNumber1" style="border-collapse: collapse">
          <tr>
            <td> </td>
          </tr>
          <tr>
            <td>&nbsp;</td>
          </tr>
          <tr>
            <td> <? 
    
//muestro los datos en un bucle 
   
    
$num_fila 0
    while (
$damefila=mysql_fetch_object($resultados)) 
           { 
           
?>
              <p style="margin-top: 0; margin-bottom: 0">
                  <br>
                  <? 
        $total_registros
++; 
          } 
//termina el bucle while 
    
    

            
    else {
        echo 
"<font color='darkgray'>(sin resultados)</font>";
    }
    
    
mysql_free_result($resultados);                
    
    if(
$total_registros) {
        
        echo 
"<center>";
        
        if((
$pagina 1) > 0) {
            echo 
"<a href='paginacion.php?pagina=".($pagina-1)."'>< Anterior</a> ";
        }
        
        for (
$i=1$i<=$total_paginas$i++){ 
            if (
$pagina == $i) {
                echo 
"<b>".$pagina."</b> "
            } else {
                echo 
"<a href='paginacion.php?pagina=$i'>$i</a> "
            }    
        }
      
        if((
$pagina 1)<=$total_paginas) {
            echo 
" <a href='paginacion.php?pagina=".($pagina+1)."'>Siguiente ></a>";
        }
        
        echo 
"</center>";
        
    }
?></td></tr></table>
     <? mysql_close($conn);?>
</body>
</html>
__________________
paty :adios:
  #7 (permalink)  
Antiguo 31/03/2008, 13:18
Avatar de bandolera_triste  
Fecha de Ingreso: noviembre-2007
Mensajes: 136
Antigüedad: 16 años, 4 meses
Puntos: 0
Re: problema en la paginación de mi consulta

gracias .. con lo de okram, pues si es necesario hacer doble la consulta porke en la primera me dice el numero de regisstros ke hay en mi consulta, ya ke con el total de registros ke salieron en mi pagina entre el numero de registros ke deseo mostrar en mi pagina ya con el limite, es el numero de paginas ke habra en mi paginación..
pero ya logre ke funcionara con la primera hoja, pero ahora mi problema es pasar a la segunda hoja, ya ke al pasar se deben de mandar todas las demas variables ke determinaran los criterios de consulta, y por url no puedo porke si son algo bastantitas para ser exacta son 10 mas la variable ke dice la pagina, el limite
y asi ke no puedo enviar tantas variables por url, asi ke he decidio implementar un form, o ustedes ke opinan?
pero no se como jiji alguien me puede asesorar?
  #8 (permalink)  
Antiguo 31/03/2008, 13:26
Avatar de GatorV
$this->role('moderador');
 
Fecha de Ingreso: mayo-2006
Ubicación: /home/ams/
Mensajes: 38.567
Antigüedad: 17 años, 11 meses
Puntos: 2135
Re: problema en la paginación de mi consulta

Mejor para que no batalles mucho utiliza una sesión y guarda los datos ahí, así podrás recuperarlos en los demás scripts.

Saludos.
  #9 (permalink)  
Antiguo 04/04/2008, 14:15
Avatar de bandolera_triste  
Fecha de Ingreso: noviembre-2007
Mensajes: 136
Antigüedad: 16 años, 4 meses
Puntos: 0
Re: problema en la paginación de mi consulta

ps ya sta listo, perdon por la tardanza pero tuve ke hacer otras cosas
aki les dejo el codigo ke hice

<head>
<SCRIPT LANGUAGE="JavaScript">
function Enviar(form) {
form.submit();
}
</SCRIPT>


<?php
include("conexion.php");
$pagina = $_POST["pagina"];
$registros = 5;
if (!$pagina) {
$inicio = 0;
$pagina = 1;
}
else {
$inicio = ($pagina - 1) * $registros;
}
//variables tomadas de los criterios para buscar viviendas
$tipo = $_POST['tipo'];
$playa = $_POST['playa'];
$categoria = "PLAYA";
$precioinicial =$_POST['precioinicial'];
$preciofinal =$_POST['preciofinal'];
$disponible ="SI";
$nh =$_POST['nh'];
$operaciones =$_POST['operaciones'];
$jardin=$_POST['jardin'];
$alberca=$_POST['alberca'];
$vigilancia=$_POST['vigilancia'];
$internet=$_POST['internet'];

$query = "SELECT vivienda.id_v, vivienda.tipo_v, vivienda.precio_d, vivienda.operacion, imagen.img1 from vivienda left join detalle_vivienda on detalle_vivienda.id_v = vivienda.id_v left join imagen on imagen.id_v = vivienda.id_v WHERE 1=1";
if ($playa !== "opc")
{$query.= " AND vivienda.id_v like '{$playa}%'";}
if ($tipo !== "opc")
{$query.= " AND vivienda.tipo_v = '{$tipo}'";}
if ($categoria !== "opc")
{$query.= " AND vivienda.categoria = '{$categoria}'";}
if (($precioinicial !== "opc")&&($preciofinal == "opc"))
{$query.= " AND vivienda.precio_d >= '{$precioinicial}'";}
if (($precioinicial == "opc")&&($preciofinal !== "opc"))
{$query.= " AND vivienda.precio_d <= '{$preciofinal}'";}
if ($disponible !== "opc")
{$query.= " AND vivienda.disponible = '{$disponible}'";}
if ($operaciones !== "opc")
{$query.= " AND vivienda.operacion like '%{$operaciones}%'";}
if ($nh !== "opc")
{$query.= " AND detalle_vivienda.n_habitacion = '{$nh}'";}

$res=mysql_query($query);
$total_registros = mysql_num_rows($res);

//para mostrar consulta con limit
$query2 = "SELECT vivienda.id_v, vivienda.tipo_v, vivienda.precio_d, vivienda.operacion, imagen.img1 from vivienda left join detalle_vivienda on detalle_vivienda.id_v = vivienda.id_v left join imagen on imagen.id_v = vivienda.id_v WHERE 1=1";
if ($playa !== "opc")
{$query.= " AND vivienda.id_v like '{$playa}%'";}
if ($tipo !== "opc")
{$query.= " AND vivienda.tipo_v = '{$tipo}'";}
if ($categoria !== "opc")
{$query.= " AND vivienda.categoria = '{$categoria}'";}
if (($precioinicial !== "opc")&&($preciofinal == "opc"))
{$query.= " AND vivienda.precio_d >= '{$precioinicial}'";}
if (($precioinicial == "opc")&&($preciofinal !== "opc"))
{$query.= " AND vivienda.precio_d <= '{$preciofinal}'";}
if ($disponible !== "opc")
{$query.= " AND vivienda.disponible = '{$disponible}'";}
if ($operaciones !== "opc")
{$query.= " AND vivienda.operacion like '%{$operaciones}%'";}
if ($nh !== "opc")
{$query.= " AND detalle_vivienda.n_habitacion = '{$nh}'";}
$query.= " LIMIT $inicio,$registros";
$res2=mysql_query($query);
echo $res2;
$total_paginas = ceil($total_registros/$res2);
?>
</head>

y dentro del body: (utilise un form con metodo post para pasar todas las variables de pagina en pagina, al igual al inicio de la consulta.. ya ke eran demasiados criterios. saludos, es un chorote pero ps ya salio.. ahora a implemetar sesiones..

<body>
<table border=1 align=center width=100%>
<tr>
<th BGCOLOR = #FFFF99><font color="#000033" size="5">FOTOS</font></th>
<th BGCOLOR = #FFFF99><font color="#000033" size="5">DETALLES</font></th>
</tr>

<?

if($total_registros) {
while (list($id_v,$tipo_v,$precio_d,$operacion,$img1) = mysql_fetch_array($res2))
{
echo "
<tr>
<td align='center'>
<img src='$img1' name='slideshow' high='250' width='230'>&nbsp;&nbsp;
</td>
<td><font color='#000000' size='4'>
<b>CLAVE:</b>$id_v<br>
<b>TIPO DE VIVIENDA:</b>$tipo_v<br>

<B>PRECIO X NOCHE:</B>$precio_d<BR>
<B>OPERACION:</B>$operacion<BR>
<a href='verplayas.php?id_v=$id_v'><B>DA CLICK AQUI PARA VER DETALLES Y MÁS FOTOGRAFÍAS...</B></a><BR>
</font>
</td>
</tr>";
}//cierre del while
}
else {
echo "<tr><td><center><font color='darkgray' size='4'>(sin resultados)</font></center></td></tr>
";

}

//paginación
mysql_free_result($res);
mysql_free_result($res2);

if($total_registros) {
echo "<center>";

if(($pagina - 1) > 0) {
echo " <form name='form' method='POST'>";
$hoja=0;
$hoja=$pagina-1;
echo "<input type='hidden' name='pagina' value='$hoja'>";
echo "<input type='hidden' name='tipo' value='$tipo'>";
echo "<input type='hidden' name='playa' value='$playa'>";
echo "<input type='hidden' name='categoria' value='PLAYA'>";
echo "<input type='hidden' name='precioinicial' value='$precioinicial'>";
echo "<input type='hidden' name='preciofinal' value='$preciofinal'>";
echo "<input type='hidden' name='disponible' value='SI'>";
echo "<input type='hidden' name='nh' value='$nh'>";
echo "<input type='hidden' name='operaciones' value='$operaciones'>";
echo "<input type='hidden' name='jardin' value='$jardin'>";
echo "<input type='hidden' name='alberca' value='$alberca'>";
echo "<input type='hidden' name='internet' value='$internet'>";
echo "<input type='hidden' name='vigilancia' value='$vigilancia'>";
echo "<input type='button' value='Anterior' href='playasresultado.php' onClick='return Enviar(this.form)'>";
echo "<FONT color='FFFFFF'>ANTERIOR</FONT>";
//echo " <a href='playasresultado.php?pagina=".($pagina-1)."'><font color='000000'>< Anterior</font></a> ";
echo "</form>";
}

for ($i=1; $i<=$total_paginas; $i++){
if ($pagina == $i) {
echo "<b><font color='#000000' size='3'> PAGINA: $pagina</font></b> ";
} else {
echo " <form name='form' method='POST'>";
echo "<input type='hidden' name='pagina' value='$i'>";
echo "<input type='hidden' name='tipo' value='$tipo'>";
echo "<input type='hidden' name='playa' value='$playa'>";
echo "<input type='hidden' name='categoria' value='PLAYA'>";
echo "<input type='hidden' name='precioinicial' value='$precioinicial'>";
echo "<input type='hidden' name='preciofinal' value='$preciofinal'>";
echo "<input type='hidden' name='disponible' value='SI'>";
echo "<input type='hidden' name='nh' value='$nh'>";
echo "<input type='hidden' name='operaciones' value='$operaciones'>";
echo "<input type='hidden' name='jardin' value='$jardin'>";
echo "<input type='hidden' name='alberca' value='$alberca'>";
echo "<input type='hidden' name='internet' value='$internet'>";
echo "<input type='hidden' name='vigilancia' value='$vigilancia'>";
echo "<input type='button' value='$i' href='playasresultado.php' onClick='return Enviar(this.form)'>";
// echo "<a href='playasresultado.php?pagina=$i&tipo_v=$tipo_v '>$i</a> ";
echo "</form>";

}
}

if(($pagina + 1)<=$total_paginas) {
echo " <form name='form' method='POST'>";
$hojita=0;
$hojita=$pagina+1;
echo "<input type='hidden' name='pagina' value='$hojita'>";
echo "<input type='hidden' name='tipo' value='$tipo'>";
echo "<input type='hidden' name='playa' value='$playa'>";
echo "<input type='hidden' name='categoria' value='PLAYA'>";
echo "<input type='hidden' name='precioinicial' value='$precioinicial'>";
echo "<input type='hidden' name='preciofinal' value='$preciofinal'>";
echo "<input type='hidden' name='disponible' value='SI'>";
echo "<input type='hidden' name='nh' value='$nh'>";
echo "<input type='hidden' name='operaciones' value='$operaciones'>";
echo "<input type='hidden' name='jardin' value='$jardin'>";
echo "<input type='hidden' name='alberca' value='$alberca'>";
echo "<input type='hidden' name='internet' value='$internet'>";
echo "<input type='hidden' name='vigilancia' value='$vigilancia'>";
echo "<input type='button' value='Siguiente' href='playasresultado.php' onClick='return Enviar(this.form)'><font color='FFFFFF'>SIGUIENTE</font>";
echo "</form>";
//echo " <a href='playasresultado.php?pagina=".($pagina+1)."'> Siguiente ></a>";
}

echo "</center>";

}
?>
</table>

<?php mysql_close($conex);?>

</body>
  #10 (permalink)  
Antiguo 04/04/2008, 14:36
(Desactivado)
 
Fecha de Ingreso: diciembre-2006
Mensajes: 225
Antigüedad: 17 años, 4 meses
Puntos: 1
Re: problema en la paginación de mi consulta

el problema es q la query no se esta ejecutando por eso no te devuelve nada y como no hay nada te bota un warning de division por 0 q es un error de php proba en las querys q tienes prueba cada una a ver si funcan de verdad
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 08:37.