UNIDAD 5: PHP REGISTROS Y ARCHIVO SECUENCIALES

TEMA 9: BAJAS O ELIMINACION MYSQL

Eliminacion o bajas es el proceso por medio del cual algunos registros del archivo son purgados del archivo, existen dos maneras por las cuales se puede realizar ese proceso.

En la primera manera de la cual se proporciona el ejemplo correspondiente se usaran dos archivos, el archivo original y un archivo temporal, el procedimiento o algoritmo es muy sencillo, se lee el registro del archivo original y si no es el registro a eliminar entonces se almacena en el archivo temporal, cuando se termina de procesar todo el archivo original, el archivo temporal solo contendra todos los registros que no se quisieron eliminar, ya con estos dos archivo se procede a eliminar o borrar usando la instruccion unlink de php el archivo original y se procede a renombrar usando la instruccion rename de php el archivo temporal como nuevo archivo original.

Prog23.html

<HTML>
<FORM ACTION=prog23.php METHOD=post>
DAME CLAVE A ELIMINAR:<INPUT TYPE=text NAME=CLAVE><BR>
<INPUT TYPE=submit NAME=OK VALUE="baja"><BR>
</FORM></HTML>
<?php
if ($OK == "baja") {
// abriendo dos archivos
$archivo=fopen('alumnos.dat','a+');
$archt=fopen('temporal.dat','a+') or dye ("no puedo crear archivo") ;
// leyendo el archivo original
while (!feof($archivo))
{
$clave=fgets($archivo);
$nombre=fgets($archivo);
$edad=fgets($archivo);
$estatura=fgets($archivo);
// convirtiendo al mismo tipo
settype($clave,"integer");
if( $CLAVE != $clave and $clave != 0 )
{
// cargando al archivo temporal
fputs($archt, $clave."\n");
// ojo aqui ya es string
fputs($archt, $nombre);
fputs($archt, $edad);
fputs($archt, $estatura);
};
};
// cerrando los dos archivos
fclose($archivo);
fclose($archt);
// eliminando archivo original
unlink("alumnos.dat");
// renombrando temporal como original
rename("temporal.dat","alumnos.dat");
// avisando
echo "registro eliminado";
};
?>

Corrida:

image109.jpg

EL problema con esta manera de eliminar incluso fisicamente los registros del archivo es que no hay manera de recuperar esa informacion posteriormente.

Es por eso que otra tecnica comun de eliminacion es incluir un campo de estado, status o bandera o semaforo en el registro y conforme se va cargando el registro y antes de mandarlo a disco se le agrega a dicho campo el caracter 'A' –>alta, asi que cuando se quiera una baja solo se pondria dicho campo en 'B' y todos los programas de lectura, busqueda y filtros deberan revisar esta campo de estado antes de hacer algo con el registro.

TAREAS PROGRAMACION ARCHIVOS DISCO PHP MYSQL :

Construir programas de eliminacion usando los dos metodos( bajas fisicas como en el ejemplo y bajas logicas como se indica en el ultimo parrafo) para los archivos construidos, para este ultimo caso se deberan reconstruir todos los programas anteriores,

Politica de Privacidad