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:
pagina1.html
<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:
pagina2.php
<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 la propiedad 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":
pagina3.php
<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>
Copiar el contenido de este cuadro de texto al VS Code y almacenarlo en la carpeta c:\xampp\htdocs con un nombre con extensión php.
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ó)
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.