Foros del Web » Programando para Internet » PHP »

alinear en columna los resultados de una consulta!

Estas en el tema de alinear en columna los resultados de una consulta! en el foro de PHP en Foros del Web. Hola a todos amigos, estoy nuevamente molestandoles, necesito alinear los resultados de una consulta en tablas ocea.. en varias columnas de a 4 por ejemplo.. ...
  #1 (permalink)  
Antiguo 10/07/2009, 14:02
 
Fecha de Ingreso: julio-2009
Ubicación: Paraguay
Mensajes: 36
Antigüedad: 15 años, 4 meses
Puntos: 0
Exclamación alinear en columna los resultados de una consulta!

Hola a todos amigos, estoy nuevamente molestandoles, necesito alinear los resultados de una consulta en tablas ocea.. en varias columnas de a 4 por ejemplo.. los resultados son una imagen y un nombre que son de cada usuario que esta registrado, pero quiero que eso me salga en columnas de 4. aca esta el codigo de mi consulta para que vean las variables y toda la cosa.

<?

$conexion = mysql_connect('localhost', 'root', ''); // se conecta con el servidor

mysql_select_db('user', $conexion); // selecciona la base de datos

$tabla = mysql_query("SELECT id, nick, rutaimg FROM usuarios ORDER BY nombre ASC"); // selecciono todos los registros de la

tabla usuarios, ordenado por nombre

while ($registro = mysql_fetch_array($tabla)) { // comienza un bucle que leera todos los registros y ejecutara las ordenes que siguen

if ($registro['id'] != $id){

echo "<br><a href='perfil.php?id=". $registro['id']."'><img src=".$registro['rutaimg']." height='80' <br><br> "; // imprime la imagen

echo ' ' . $registro['nick'] . '</a> '; // imprime el nombre

}



} // fin del bucle de ordenes

mysql_free_result($tabla); // libera los registros de la tabla

mysql_close($conexion); // cierra la conexion con la base de datos


?>

esos resultados quiero alinear en columnas de 4! muchas gracias de antemano!
  #2 (permalink)  
Antiguo 10/07/2009, 14:35
Avatar de GatorV
$this->role('moderador');
 
Fecha de Ingreso: mayo-2006
Ubicación: /home/ams/
Mensajes: 38.567
Antigüedad: 18 años, 6 meses
Puntos: 2135
Respuesta: alinear en columna los resultados de una consulta!

http://www.forosdelweb.com/wiki/PHP:...en_columnas%3F

Saludos.
  #3 (permalink)  
Antiguo 10/07/2009, 14:42
 
Fecha de Ingreso: julio-2009
Ubicación: Paraguay
Mensajes: 36
Antigüedad: 15 años, 4 meses
Puntos: 0
Exclamación Respuesta: alinear en columna los resultados de una consulta!

si encontre este articulo, pero no se como aplicarlo segun mis variables.. aqui esta el archivo..

<?php
echo "<table align=center>";

$columnes = 4; # Número de columnas (variable)

if (($rows=mysql_num_rows($result))==0) {
echo "<tr><td colspan=$columnes>No hay resultados en la BD.</td></tr> ";
} else {
echo "<tr><td colspan=$columnes>$rows Resultados </td></tr>";
}

for ($i=1; $row = mysql_fetch_row ($result); $i++) {
$resto = ($i % $columnes); # Número de celda del <tr> en que nos encontramos
if ($resto == 1) {echo "<tr>";} # Si es la primera celda, abrimos <tr>
echo "<td>$row[1]</td>";
if ($resto == 0) {echo "</tr>";} # Si es la última celda, cerramos </tr>
}
if ($resto <> 0) { # Si el resultado no es múltiple de $columnes acabamos de rellenar los huecos
$ajust = $columnes - $resto; # Número de huecos necesarios
for ($j = 0; $j < $ajust; $j++) {echo "<td>&nbsp;</td>";}
echo "</tr>"; # Cerramos la última línea </tr>
}
mysql_close($connexion);
echo "</table>";
?>


pero no se como aplicarlo... si alguien me ayuda. gracias!
  #4 (permalink)  
Antiguo 12/07/2009, 01:14
 
Fecha de Ingreso: julio-2009
Ubicación: Paraguay
Mensajes: 36
Antigüedad: 15 años, 4 meses
Puntos: 0
Exclamación Respuesta: alinear en columna los resultados de una consulta!

pude solucionarlo, gracias.. pero el script tiene un error.. en lugar de mostrarme todos los usuarios de la base de datos.. me muestra solo el total menos uno.. una prueba, registre tres usuarios: mario,mariam y ana... y al usar el script que es este


<?

echo '<br><br><b><big><big>Amigos</b><br><br>';
$conexion = mysql_connect('localhost', 'root', ''); // se conecta con el servidor

mysql_select_db('user', $conexion); // selecciona la base de datos

$tabla = mysql_query("SELECT id, nick, rutaimg FROM usuarios ORDER BY nombre ASC"); //

while ($row = mysql_fetch_array($tabla)) { // comienza un bucle que leera todos los registros y ejecutara las ordenes que

siguen




echo "<table align=center>";

$columnes = 4; # Número de columnas (variable)

if (($rows=mysql_num_rows($tabla))==0) {
echo "<tr><td colspan=$columnes>No hay resultados en la BD.</td></tr> ";
} else {
echo "<tr><td colspan=$columnes>$rows Resultados </td></tr>";
}

for ($i=1; $row = mysql_fetch_row ($tabla); $i++) {
$resto = ($i % $columnes); # Número de celda del <tr> en que nos encontramos
if ($resto == 1) {echo "<tr>";} # Si es la primera celda, abrimos <tr>
echo "<td>$row[1]</td>";
if ($resto == 0) {echo "</tr>";} # Si es la última celda, cerramos </tr>
}
if ($resto <> 0) { # Si el resultado no es múltiple de $columnes acabamos de rellenar los huecos
$ajust = $columnes - $resto; # Número de huecos necesarios
for ($j = 0; $j < $ajust; $j++) {echo "<td>&nbsp;</td>";}
echo "</tr>"; # Cerramos la última línea </tr>
}

echo "</table>";









} // fin del bucle de ordenes

mysql_free_result($tabla); // libera los registros de la tabla

mysql_close($conexion); // cierra la conexion con la base de datos


?>


me sale asi:

3 resultados
mario,mariam

entienden? solo me muestra dos de ellos pero en la cuenta me dice lo correcto que hay tres.. alguna idea de porque?
  #5 (permalink)  
Antiguo 12/07/2009, 12:26
Avatar de GatorV
$this->role('moderador');
 
Fecha de Ingreso: mayo-2006
Ubicación: /home/ams/
Mensajes: 38.567
Antigüedad: 18 años, 6 meses
Puntos: 2135
Respuesta: alinear en columna los resultados de una consulta!

Es porque usas primero un while() y luego un for() tienes que adaptar el script como el de las FAQs y solo usar el for().

Saludos.
  #6 (permalink)  
Antiguo 12/07/2009, 18:07
 
Fecha de Ingreso: julio-2009
Ubicación: Paraguay
Mensajes: 36
Antigüedad: 15 años, 4 meses
Puntos: 0
Respuesta: alinear en columna los resultados de una consulta!

pero no se como hacerlo.. te tomarias la molestia de unir los dos por for() o por un while() porque de esto si que no tengo la mas minima idea. muchisimas gracias!!
te lo agradeceria mucho encerio!
  #7 (permalink)  
Antiguo 12/07/2009, 18:24
 
Fecha de Ingreso: julio-2009
Ubicación: Paraguay
Mensajes: 36
Antigüedad: 15 años, 4 meses
Puntos: 0
Respuesta: alinear en columna los resultados de una consulta!

ya lo pude solucionar! muchisimas gracias!!!
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:11.