Search code examples
phpmysqlcheckboxsql-deletedelete-row

Deleting multiple MySQL items using checkboxes


I have a form that enables user to select several items:

<table>
<form name="delete" action="proceed.php" method="post">
<?php 
 require_once 'cnn.php';
 $viewPhoto = mysqli_query($cnn, "SELECT * FROM competition WHERE round = 2 ORDER BY id Desc");


                while($row = mysqli_fetch_array($viewPhoto)) {    ?>

<tr><td><input type="checkbox" name="check[]" value="<?php echo $row['id']; ?>"></td>
<td><?php echo $row['id']; ?></td>
<td><img title="" src="<?php echo $row['url']; ?>"  width="178" height="150" /></td></tr>                   

<?php } ?>
<input type="submit" name="delete" value="Delete items">
</form>
</table>

The proceed.php then includes:

<?php
 require_once 'cnn.php';
 $sql = mysqli_query($cnn, "SELECT * FROM competition");

 if(isset($_POST['delete'])){
   foreach ($_POST["check"] as $id){
   $sql = "DELETE FROM soutez WHERE id='$id'";
}
   echo "Items deleted";
}
?>

However, the items are not deleted from database. Where could be the mistake?


Solution

  • You are missing executing actual query in loop for deleting record

    <?php
     require_once 'cnn.php';
     $sql = mysqli_query($cnn, "SELECT * FROM soutez");
    
     if(isset($_POST['delete'])){
       foreach ($_POST["check"] as $id){
       $sql = "DELETE FROM soutez WHERE id='$id'";
       //Here you are missing below statement
       mysqli_query($cnn, $sql);
    }
       echo "Items deleted";
    }
    ?>