Foros del Web » Programando para Internet » PHP »

El while no se me ejecuta como debiera porque?

Estas en el tema de El while no se me ejecuta como debiera porque? en el foro de PHP en Foros del Web. Buenas amigos necesito una mano tengo varios while dentro de un if pero el primero de ellos saca solo un dato de la tabla cuando ...
  #1 (permalink)  
Antiguo 03/10/2010, 16:20
 
Fecha de Ingreso: agosto-2010
Mensajes: 44
Antigüedad: 13 años, 8 meses
Puntos: 0
El while no se me ejecuta como debiera porque?

Buenas amigos necesito una mano tengo varios while dentro de un if pero el primero de ellos saca solo un dato de la tabla cuando debiera sacar todos los que haya seleccionado el SELECT..Seguro no estoy implementando el codigo de una buena manera..Muchas gracias al que pueda ayudarme...
Este es el codigo..

$result = mysql_query("SELECT ced_facilitador FROM facilitador_unidadcurricular where cod_unidadcurricular='$cod_unidadcurricular'");

if($row = mysql_fetch_row($result)){
echo "<table border='2' width='75%' align='center'>";
echo "<tr>";
echo "<td><b>Cedula del Facilitador</b></td>";
echo "<td><b>Nombre</b></td>";
echo "<td><b>Apellido</b></td>";
echo "<td><b>Unidad Curricular</b></td>";
echo "<td><b>Trayecto</b></td>";
echo "<td><b>Trimestre</b></td>";
echo "</tr>";


echo "<tr>";
while ($row = mysql_fetch_row($result)){
echo "<td>$row[0]</td>";
$ced_facilitador=$row[0];

$sqlm = mysql_query("SELECT nombre,apellido FROM facilitador where ced_facilitador='$ced_facilitador'");

while ($row = mysql_fetch_row($sqlm)){
echo "<td>$row[0]</td>";
echo "<td>$row[1]</td>";}
$sq = mysql_query("SELECT descripcion,trayecto,trimestre FROM unidadcurricular where cod_unidadcurricular='$cod_unidadcurricular'");
while ($row = mysql_fetch_row($sq)){
echo "<td>$row[0]</td>";
echo "<td>$row[1]</td>";
echo "<td>$row[2]</td>";
}

echo "</tr> ";
}
echo "</table>";





desconectar();

?>
<html>
<head>
<title>Consultas de Facilitadores/Unidades Curriculares</title>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
</head>
<body><br><br>

<form action="" method="get">
<table border='0' width='40%' align='center'>
<tr><td>
<input type="button" name="imprimir" value="Imprimir"Â* onClick="window.print();"/></td>
<td><input type="button" name="borrar" value="Regresar" onClick="window.history.go(-1);"/></td>
</tr>
</form>
</body>
</html>
<?php

}else{
echo '<script type="text/javascript">alert("Registro inexistente");</script>';
echo '<script type="text/javascript">window.history.go(-1);</script>';}

?>
  #2 (permalink)  
Antiguo 03/10/2010, 22:13
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
Tema movido desde Mysql a PHP
  #3 (permalink)  
Antiguo 03/10/2010, 23:03
Avatar de HackmanC  
Fecha de Ingreso: enero-2008
Ubicación: Guatemala
Mensajes: 1.817
Antigüedad: 16 años, 2 meses
Puntos: 260
Sonrisa Respuesta: El while no se me ejecuta como debiera porque?

Hola,

Cita:
Iniciado por Rene1607 Ver Mensaje
... tengo varios while dentro de un if pero el primero de ellos saca solo un dato de la tabla cuando debiera sacar todos ...
Con esa descripción fácilmente se presta a confusión, 'saca solo un dato de la tabla' pareciera que te muestra solo el primero, cuando realmente no es así. Lo que está sucediendo es que 'no muestra el primer registro de la tabla'.

Cita:
Iniciado por Rene1607 Ver Mensaje
if($row = mysql_fetch_row($result)){
Con la instrucción anterior estas avanzando el apuntador un paso adelante por eso se salta el primer registro. Posiblemente prueba a cambiarlo por mysql_num_rows.

Código PHP:
if (mysql_num_rows($result)){ 
Saludos,
  #4 (permalink)  
Antiguo 04/10/2010, 00:26
 
Fecha de Ingreso: agosto-2010
Mensajes: 44
Antigüedad: 13 años, 8 meses
Puntos: 0
Respuesta: El while no se me ejecuta como debiera porque?

Gracias hermano con tu consejo resolvi el problema era eso solo cambiar el fetch por num en el "if"..Disculpa pero soy nuevo en esto de la programacion, es la primera aplicacion que hago y creo que me falta mucho por aprender..Sobre todo en esto de ejecutar bucles correctamente...Muchas gracias HackmanC..

Etiquetas: Ninguno
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 23:23.