Ver Mensaje Individual
  #7 (permalink)  
Antiguo 18/08/2012, 10:23
Avatar de Nemutagk
Nemutagk
Colaborador
 
Fecha de Ingreso: marzo-2004
Ubicación: México
Mensajes: 2.633
Antigüedad: 20 años, 1 mes
Puntos: 406
Respuesta: Consulta mysql con array

Sin ofender amiga, pero tu código esta un poco "patas arriba" >.<, vemos como solucionamos esto...

Comenzamos con que DEBES DEPURAR TUS CONSULTAS SQL SIEMPRE, porque de esto?, pues muy facil, muchas veces cometemos errores tipográficos en las sentencias SQL, pero estos errores no se muestran en pantalla automaticamente, y lo unico que sucede es que la query no retorna ningún resultado, para esto agrega SIEMPRE en mysql_query, mysql_connect, mysql_select_db, etc la función mysql_error de la siguiente manera:

Código PHP:
Ver original
  1. <?php
  2. $conexion = mysql_connect($host,$user,$pass) or die(mysql_error());
  3. mysql_select_db($db,$conexion) or die(mysql_error());
  4.  
  5. $sql = 'SELECT * FROM mitabla';
  6. mysql_query($sql,$conexion) or die(mysql_error());

Ahora, en el código que has publicado en la linea 4 ejecutas una query PERO, en la linea 6 sobre escribes el resultado de la query anterior, si no vas a usar la query anterior no la agregues >.<

En la linea 15 no le veo sentido a tu for amiga, solo veo que defines valores a varias variables PERO se sobre escriben en la siguiente iteración del loop, por lo tanto es ilógico =/

En la linea 35 de nuevo generas una query PERO es igual al query de la linea 6 unicamente cambia el orden de los resultados...

Por ultimo en la linea 46 haces un nuevo loop while, por lo cual si la sentencia arroja mas de 1 resultado el form se repetirá según el numero de items arrojados...

En fin, son varios errores que tiene tu código, pero se puede rescatar la idea original, no podré generarte un código para hacer copy/paste, al menos no al 100%, pero será "facil" adaptar a tus necesidades, OJO, que el código generado es lo que al final YO ENTENDI, el resultado puede ser diferente a lo que pretendes >.<

Código PHP:
Ver original
  1. <?php
  2.  
  3. <?php
  4.  
  5. if (isset($_GET['nombre_etiqueta'])) {
  6.     $nombre_etiqueta = $_GET['nombre_etiqueta'];
  7.  
  8.     $sql = 'SELECT * FROM detalle_etiquetas WHERE nombre_etiqueta="'.$nombre_etiqueta.'"';
  9.     $query = mysql_query($sql,$conn) or die(mysql_error());
  10.  
  11.     $campos = array();
  12.     while($row = mysql_fetch_assoc($query)) {
  13.         $campos[] = $row['id_plan'];   
  14.     }
  15.  
  16.     /*
  17.     * No eh usado la clase PHPPaging, pero paginaremos a mano, aquí
  18.     * puedes usar el metodo que prefieras...
  19.     */
  20.  
  21.     $sql = 'SELECT COUNT(*) FROM planes WHERE id_plan IN('.implode(',',$campos).') ORDER BY id_plan ASC';
  22.     $query = mysql_query($sql,$conn) or die(mysql_error());
  23.  
  24.     //Definimos en que pagina estamos, si existe $_GET['pag'] obtenemos su valor, de lo contrario será 1
  25.     $pagActual = isset($_GET['pag']) ? $_GET['pag'] : 1;
  26.     //obtenemos el total de items...
  27.     $totalItems = mysql_result($query, 0);
  28.     //defines el numero de items que se mostrarán por página
  29.     $itemsPorPagina = 25;
  30.     //calculamos las páginas
  31.     $totalPags = ceil($totalItems / $itemsPorPagina);
  32.     //calculamos desde que item nos devolvera mysql
  33.     $itemInicio = $itemsPorPagina * ($pagActual - 1);
  34.  
  35.     //por fin hacemos la sentencia para recuperar los items...
  36.     $sql = 'SELECT * FROM planes WHERE id_plan IN('.implode(',',$campos).' ORDER BY id_plan ASC LIMIT '.$itemInicio.','.$itemsPorPagina;
  37.     $query = mysql_query($sql,$conn) or die(mysql_error());
  38.  
  39.     $rut = "xxx/xxx/logos/";
  40.  
  41.     while($row = mysql_fetch_assoc($query)) {
  42.         $id_plan = $query4['id_plan'];
  43.         $id_posada = $query4['id_posada'];
  44.         $nombre_posada = $query4['nombre_posada'];      
  45.         $nombre_plan = $query4['nombre_plan'];
  46.         $descripcion_plan = $query4['descripcion_plan'];
  47.         $incluye = $query4['incluye'];
  48.         $desde = $query4['desde'];
  49.         $hasta = $query4['hasta'];
  50.         $precio_adultos_a = $query4['precio_adultos_a'];
  51.  
  52.         $lafoto = $id_posada . "_" . $id_plan . "." . "jpg";
  53.  
  54.             echo
  55.         "
  56.        <form action='cotizacion2.php' method='get'>
  57.        
  58.        <table id='tabla_plan' class='borde'>
  59.            <tr>
  60.                <td><input name='id_plan' type='hidden' value='".$id_plan."' />
  61.                <input name='id_posada' type='hidden' value='".$id_posada."' />
  62.                <input name='nombre_posada' type='hidden' value='".$nombre_posada."' />
  63.                    <h3>$nombre_plan</h3>
  64.                    <input name='nombre_plan' type='hidden' value='".$nombre_plan."' />
  65.                    <br>
  66.                    <img src='$rut$lafoto' />
  67.                </td>
  68.                <td align='justify'>
  69.                    <h3>Posada: $nombre_posada</h3>
  70.                    <br>
  71.                    <h4>$descripcion_plan</h4>
  72.                    <br>
  73.                <h2><a href='javascript:f_verDetalle(".$query4["id_plan"].");'>Restaurantes asociados</a></h2>
  74.                </td>
  75.  
  76.                <td bgcolor='#FFFFD9'>
  77.                    <h2>Habitación por noche</h2>
  78.                    <br>
  79.                    <h1>Bs. $precio_adultos_a</h1>
  80.                    <br>
  81.                     <input class='bt1' name='Cotizar' value='Cotizar' type='submit' alt='SUBMIT' />
  82.                </td>
  83.         </tr>
  84.         <br>
  85.        </table>
  86.                </form>
  87.  
  88.            ";
  89.     }
  90.  
  91.     //creamos el menú paginación...
  92.     $paginacion = '<p>';
  93.     $paginacion .= ($pagActual > 1) ? '<a href="'.$_SERVER['PHP_SELF'].'?pag='.($pagActual - 1).'&nombre_etiqueta='.$nombre_etiqueta.'">Anterior</a> ' : 'Anterior ';
  94.     for($i=1; $i<=$totalPags; $i++) {
  95.         $paginacion .= ($i == $pagActual) ? '<strong>'.$i.'</strong> ' : '<a href="'.$_SERVER['PHP_SELF'].'?pag='.$i.'&nombre_etiqueta='.$nombre_etiqueta.'">'.$i.'</a> ';
  96.     }
  97.     $paginacion .= ($pagActual < $totalPags) ? '<a href="'.$_SERVER['PHP_SELF'].'?pag='.($pagActual + 1).'&nombre_etiqueta='.$nombre_etiqueta.'">Siguiente</a>' : 'Siguiente';
  98.     $paginacion .= '</p>';
  99.  
  100.     echo $paginacion;
  101. }

Nota: ojo, no lo eh probado ya que no tengo tu db, pero debería funcionar al menos teoricamente >.<

Actualización: veo que el ultimo código que publicaste no es el mismo que el anterior a este, así que me equivoqué en la variable GET 'nombre_etiqueta', el cual ya fue corregido >.<, también los comentarios que hice fueron hacia el ultimo código que publicaste, no al primero, pero de todas maneras deberías checarlos
__________________
Listo?, tendría que tener 60 puntos menos de IQ para considerarme listo!!!
-- Sheldon Cooper
http://twitter.com/nemutagk
PD: No contestaré temas vía mensaje personal =)

Última edición por Nemutagk; 18/08/2012 a las 10:34