Foros del Web » Programando para Internet » PHP »

Ayuda PHP Y MYSQL

Estas en el tema de Ayuda PHP Y MYSQL en el foro de PHP en Foros del Web. hola, el problema es basicamente quiero borrar los registros de una tabla a partir de multiples checkbox y no tengo idae como. Este es el ...
  #1 (permalink)  
Antiguo 29/10/2009, 07:59
 
Fecha de Ingreso: octubre-2009
Mensajes: 1
Antigüedad: 14 años, 6 meses
Puntos: 0
Ayuda PHP Y MYSQL

hola, el problema es basicamente quiero borrar los registros de una tabla a partir de multiples checkbox y no tengo idae como.
Este es el codigo que uso para mostrar los registros y generar los checkboxs:

<?
$d=0;
while ($row= mysql_fetch_array ($result))
{
$d++;
if ($d%2==0)
{
echo '<tr><td bgcolor="#CCCCCC"><font size="3">' .$row["apynalumnos"].'</font></td>';
echo '<td bgcolor="#CCCCCC"><font size="3">' .$row["domi"].'</font></td>';
echo '<td bgcolor="#CCCCCC"><font size="3">' .$row["documento"].'</font></td>';
echo '<td bgcolor="#CCCCCC"><font size="3">' .$row["fechanac"].'</font></td>';
echo '<td bgcolor="#CCCCCC"><font size="3">' .$row["anio"].'</font></td>';
echo '<td bgcolor="#CCCCCC"><font size="3">' .$row["division"].'</font></td>';
echo '<td bgcolor="#CCCCCC"><font size="3">' .$row["turno"].'</font></td>';
echo '<td bgcolor="#CCCCCC"><font size="3">' .$row["email"].'</font></td>';
echo '<td bgcolor="#CCCCCC"><font size="3">' .$row["telefonof"].'</font></td>';
echo '<td bgcolor="#CCCCCC"><input type="checkbox" name="lista []" value="$documento"/></td></tr>';
}
else
{
echo '<tr><td bgcolor="#999999"><font size="3">' .$row["apynalumnos"].'</font></td>';
echo '<td bgcolor="#999999"><font size="3">' .$row["domi"].'</font></td>';
echo '<td bgcolor="#999999"><font size="3">' .$row["documento"].'</font></td>';
echo '<td bgcolor="#999999"><font size="3">' .$row["fechanac"].'</font></td>';
echo '<td bgcolor="#999999"><font size="3">' .$row["anio"].'</font></td>';
echo '<td bgcolor="#999999"><font size="3">' .$row["division"].'</font></td>';
echo '<td bgcolor="#999999"><font size="3">' .$row["turno"].'</font></td>';
echo '<td bgcolor="#999999"><font size="3">' .$row["email"].'</font></td>';
echo '<td bgcolor="#999999"><font size="3">' .$row["telefonof"].'</font></td>';
echo '<td bgcolor="#999999"><input type="checkbox" name="lista []" value="$documento" /></td></tr>';
}
}
mysql_free_result ($result)
?>

espero que puedan ayudarme. Gracias
  #2 (permalink)  
Antiguo 29/10/2009, 08:26
Avatar de pateketrueke
Modernizr
 
Fecha de Ingreso: abril-2008
Ubicación: Mexihco-Tenochtitlan
Mensajes: 26.399
Antigüedad: 16 años, 1 mes
Puntos: 2534
Respuesta: Ayuda PHP Y MYSQL

cuando recibes el POST, $_POST['lista'] es un array()

de modo que debes iterar dicho array ejecutando la acción que desees, suerte!!
__________________
Y U NO RTFM? щ(ºдºщ)

No atiendo por MP nada que no sea personal.
  #3 (permalink)  
Antiguo 29/10/2009, 08:30
Avatar de dggluz  
Fecha de Ingreso: abril-2009
Ubicación: Buenos Aires, Argentina
Mensajes: 525
Antigüedad: 15 años
Puntos: 50
Respuesta: Ayuda PHP Y MYSQL

En la página que procese ese formulario:
Código PHP:
foreach($_REQUEST['lista'] as $doc)
{
    
$sql="DELETE FROM tuTabla WHERE documento=$doc;";
    
mysql_query($sql);

o bien, para hacer sólo una consulta:
Código PHP:
$arrDocs=array();
foreach(
$_REQUEST['lista'] as $doc)
{
    
array_push($arrDocs$doc);
}
$sql="DELETE FROM tuTabla WHERE documento IN (".join(", "$arrDocs).");";
mysql_query($sql); 
Todo eso siempre y cuando puedas garantizar que no tendrás dos registros con el mismo documento; si es así, directamente tendrías que cambiar tu formulario asociando los checkbox con un un campo único de tu tabla. Mejor aún si el documento es índice de la tabla (no autonumérico, obviamente). ¡Suerte!
  #4 (permalink)  
Antiguo 29/10/2009, 08:34
Avatar de pateketrueke
Modernizr
 
Fecha de Ingreso: abril-2008
Ubicación: Mexihco-Tenochtitlan
Mensajes: 26.399
Antigüedad: 16 años, 1 mes
Puntos: 2534
Respuesta: Ayuda PHP Y MYSQL

de hecho, definitivamente hacer una consulta es lo mas óptimo...

porque hacer una consulta por cada vuelta del bucle es demasiado malo, de veras!!
__________________
Y U NO RTFM? щ(ºдºщ)

No atiendo por MP nada que no sea personal.
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:31.