Temario del Tutorial29 - UPDATE (Modificación de un registro trabajando con dos tablas)


Ahora complicaremos un poco la modificación de un registro consultando dos tablas. Supongamos que un alumno desea cambiarse de curso, es decir, se inscribió en uno y quiere borrarse de ese e inscribirse en otro diferente. Debemos mostrar en un "select" el curso actual en el que está inscripto y los otros cursos disponibles en la tabla "cursos".

Para resolver este problema tenemos que plantear tres páginas, una donde ingresemos el mail del alumno, la segunda donde se pueda cambiar el curso y por última una que permita modificar la tabla "alumnos" con el nuevo curso seleccionado.

La primer página de ingreso del mail es:

<html>
<head>
<title>Problema</title>
</head>
<body>
<form action="pagina2.php" method="post">
Ingrese el mail del alumno:
<input type="text" name="mail"><br>
<input type="submit" value="buscar">
</form>
</body>
</html> 

La segunda página y la más importante en cuanto a novedades es la siguiente:

<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
$conexion=mysqli_connect("localhost","root","","base1") or
    die("Problemas con la conexión");

$registros=mysqli_query($conexion,"select * from alumnos
                        where mail='$_REQUEST[mail]'") or
  die("Problemas en el select:".mysqli_error($conexion));
if ($regalu=mysqli_fetch_array($registros))
{
?>
  <form action="pagina3.php" method="post">
  <input type="hidden" name="mailviejo" value="<?php echo $regalu['mail'] ?>">
  <select name="codigocurso">
  <?php
  $registros=mysqli_query($conexion,"select * from cursos") or
    die("Problemas en el select:".mysqli_error($conexion));
  while ($reg=mysqli_fetch_array($registros))
  {
    if ($regalu['codigocurso']==$reg['codigo'])
      echo "<option value=\"$reg[codigo]\" selected>$reg[nombrecurso]</option>";
    else
      echo "<option value=\"$reg[codigo]\">$reg[nombrecurso]</option>";
  }
  ?>
  </select>
  <br>
  <input type="submit" value="Modificar">
  </form>
  <?php
}
else
  echo "No existe alumno con dicho mail";
?>
</body>
</html>

La primera consulta de la tabla alumnos es para verificar si existe un alumno con el mail ingresado por teclado:

$registros=mysqli_query($conexion,"select * from alumnos
                        where mail='$_REQUEST[mail]'") or
  die("Problemas en el select:".mysqli_error($conexion));
if ($regalu=mysqli_fetch_array($registros))
{

En caso de existir un alumno con dicho mail, el if se verifica verdadero y pasamos a poblar el control select con los distintos cursos que contiene la tabla "cursos":

$registros=mysqli_query($conexion,"select * from cursos") or
  die("Problemas en el select:".mysqli_error($conexion));
while ($reg=mysqli_fetch_array($registros))
{
  if ($regalu['codigocurso']==$reg['codigo'])
    echo "<option value=\"$reg[codigo]\" selected>$reg[nombrecurso]</option>";
  else
    echo "<option value=\"$reg[codigo]\">$reg[nombrecurso]</option>";
}
?>
</select>

Para que aparezca seleccionado el curso actual debemos inicializar lo marca option con el texto selected. Es decir que el if dentro del while se verifica verdadero una solo vez.

Por último la tercer página procede a registrar el cambio en la tabla "alumnos":

<html>
<head>
<title>Problema</title>
</head>
<body>
<?php
$conexion=mysqli_connect("localhost","root","","base1") or
    die("Problemas con la conexión");

$registros=mysqli_query($conexion,"update alumnos
                          set codigocurso=$_REQUEST[codigocurso]
                        where mail='$_REQUEST[mailviejo]'") or
  die("Problemas en el select:".mysqli_error($conexion));
  echo "El curso fue modificado con exito";
?>
</body>
</html>


Problema resuelto.

Copiar el contenido de este cuadro de texto al NotePad++ y grabarlo en la carpeta c:\wamp\www con un nombre con extensión php (si hay varios cuadros de texto grabar cada uno en un archivo distinto).
luego abrir el navegador (Chrome, FireFox, IExplorer etc.) y en la barra de direcciones tipear: http://localhost/pagina1.php (o el nombre del archivo que le dió)

pagina1.php

Ejecutar ejemplo

pagina2.php


pagina3.php

Problema propuesto.

Confeccionar la modificación del mail, nombre y curso de la tabla "alumnos". Ingresar por teclado el código de alumno para su búsqueda.

Solución
pagina1.php

Ejecutar ejemplo
pagina2.php

pagina3.php

Retornar