Вопрос по php, mysql, drop-down-menu – Удаление нескольких строк с помощью флажков, PHP и MySQL

1

Как следует из названия, я хочу удалить несколько строк из моей базы данных. Для этого у меня есть два файла, файл переднего плана, который генерирует таблицу, в которой показаны файлы, которые пользователь может удалить, которые выбраны с помощью флажков.

Внутренний файл предназначен для обработки выбранных флажков и использования оператора SQL для удаления выбранных файлов.

Проблема, с которой я сталкиваюсь, заключается в передаче идентификатора выбранного файла из внешнего интерфейса в конец. Код для обоих файлов ниже:

Front End

//Build Table Query
$query="SELECT * FROM documents";
$result= mysqli_query($con, $query) or die("Invalid query");

$count = mysqli_affected_rows($con); 

?>
<table width="400" border="0" cellspacing="1" cellpadding="0">
<tr>
<td><form name="form1" method="post" action="deletefilesback.php">
<table width="800" border="0" cellpadding="3" cellspacing="2" bgcolor="#CCCCCC">
<tr>
<td colspan="5" bgcolor="#FFFFFF" align="center"><strong>Delete Multiple         Files</strong></td>
</tr>
<tr>
<td align="center" bgcolor="#FFFFFF">#</td>
<td align="center" bgcolor="#FFFFFF"><strong>Id</strong></td>
<td align="center" bgcolor="#FFFFFF"><strong>Title</strong></td>
<td align="center" bgcolor="#FFFFFF"><strong>Description</strong></td>
<td align="center" bgcolor="#FFFFFF"><strong>File Location</strong></td>
</tr>
<?php
while($row = mysqli_fetch_array($result)){
?>
<tr>
<td align="center" bgcolor="#FFFFFF"><input name="checkbox[]" type="checkbox"  id="checkbox[]" value="<?php echo $rows['id']; ?>"></td>
<td bgcolor="#FFFFFF"><?php echo $row['id']; ?></td>
<td bgcolor="#FFFFFF"><?php echo $row['title']; ?></td>
<td bgcolor="#FFFFFF"><?php echo $row['description']; ?></td>
<td bgcolor="#FFFFFF"><?php echo $row['doc_link']; ?></td>
</tr>
<?php
}
?>
<tr>
<td colspan="5" align="center" bgcolor="#FFFFFF"><input name="delete" type="submit"   id="delete" value="Delete Files"></td>
</tr>
</table>
</form>
</td>
</tr>
</table>

Back End

$delete = $_POST['checkbox'];

//Then do what you want with the selected items://
foreach ($delete as $id) {

$query="DELETE FROM documents WHERE id = '".$id."'";
$result= mysqli_query($con, $query) or die("Invalid query");

}
//Show that the items have been successfully removed.//
if (mysqli_affected_rows($con) > 0) {
echo '<p>The selected items have been successfully deleted.</p>';
} else {
echo '<p>An error has occurred while processing your request</p>';
}
?>

Как примечание, как только это сработает, я буду использовать функцию unlink для удаления файла на сервере, используя часть таблицы doc_link на внешнем интерфейсе. Спасибо

Пожалуйста, укажите сообщение об ошибке. GoSmash
Когда я использую $ result = mysql_query ($ query) или die (mysql_error ()); Я просто получаю пустую страницу. Maverick Johnson

Ваш Ответ

2   ответа
2

** MYSQL код ** Описание: этот код изначально создает базу данных для использования. В терминале MySQL:

`CREATE database `tester`;`

Теперь создайте таблицу для этой базы данных:

`USE tester;`

`CREATE TABLE `test_mysql` (
`id` INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY,
`name` VARCHAR(80) NOT NULL,
`lastname` VARCHAR(80) NOT NULL,
`e_mail` VARCHAR(100) NOT NULL)
ENGINE = MYISAM;`

Теперь вставьте несколько записей в вашу вновь созданную таблицу:

`INSERT INTO `test_mysql`
(`id`, `name`, `lastname`, `e_mail`)
VALUES
(NULL, 'Billly', 'Blueton', '[email protected]'),
(NULL, 'Jame', 'Campbell', '[email protected]'),
(NULL, 'Mark', 'Jackson', '[email protected]'),
(NULL, 'Linda', 'Travor', '[email protected]'),
(NULL, 'Joey', 'Ford', '[email protected]'),
(NULL, 'Sidney', 'Gibson', '[email protected]');`

Затем создайте файл PHP (HTML) с именем index.php:

** PHP & amp; HTML-код **

`<h1>Deleting Multiple Records using PHP &amp; MySQL</h1>
<p>&nbsp;</p>
<?php
$host="localhost"; // Host name
$username="root"; // Mysql username
$password=""; // Mysql password
$db_name="tester"; // Changed database name
$tbl_name="test_mysql";
mysql_connect($host, $username, $password)or die("cannot connect");
mysql_select_db($db_name)or die("cannot select DB");
$sql="SELECT * FROM $tbl_name";
$result=mysql_query($sql);
$count=mysql_num_rows($result);
?>
<table width="400" border="0" cellspacing="1" cellpadding="0">
<tr><td><form name="form1" method="post" action="">
<table width="400" border="0" cellpadding="3" cellspacing="1" bgcolor="#CCCCCC"><tr>
<td bgcolor="#FFFFFF">&nbsp;</td>
<td colspan="4" bgcolor="#FFFFFF"><strong>Delete multiple rows in mysql</strong> </td>           </tr>
<tr><td align="center" bgcolor="#FFFFFF">#</td>
<td align="center" bgcolor="#FFFFFF"><strong>Id</strong></td>
<td align="center" bgcolor="#FFFFFF"><strong>Name</strong></td>
<td align="center" bgcolor="#FFFFFF"><strong>Lastname</strong></td>
<td align="center" bgcolor="#FFFFFF"><strong>Email</strong></td></tr>
<?php while($rows=mysql_fetch_array($result, MYSQL_ASSOC)){ ?>

<tr><td align="center" bgcolor="#FFFFFF">
<input name="checkbox[]" type="checkbox" id="checkbox[]" value="<? echo $rows['id']; ?>">
</td><td bgcolor="#FFFFFF"><?php echo $rows['id']; ?></td><td bgcolor="#FFFFFF">
<?php echo $rows['name']; ?></td><td bgcolor="#FFFFFF"><?php echo $rows['lastname']; ?>    </td>
<td bgcolor="#FFFFFF"><?php echo $rows['e_mail']; ?>
</td></tr>
<?php } ?>
<tr><td colspan="5" align="center" bgcolor="#FFFFFF">
<input name="delete" type="submit" id="delete" value="Delete"></td></tr>
<?php

if(isset($_POST['delete'])){
$checkbox = $_POST['checkbox'];
for($i=0;$i<count($_POST['checkbox']);$i++){
$del_id = $checkbox[$i];
$sql = "DELETE FROM $tbl_name WHERE id='$del_id'";
print $sql;
$result = mysql_query($sql);}

if($result){echo "<meta http-equiv=\"refresh\" content=\"0;URL=index.php\">";}}
mysql_close();
?>
</table></form></td></tr></table>
<p>Record count: <?php echo number_format($count) ?></p>`
В моем последнем посте, пожалуйста, не обращайте внимания на начальные и конечные отметки в начале и конце кода. Я думал, что это необходимо, чтобы представить свой код. Лео
Просто нажмите на кнопку & quot; изменить & quot; связать и удалить их. Легко, как пирог (и проще, чем комментировать ...). Кстати, он должен дать вам первую партию.
3

<input name="checkbox[<?php echo $row['id']?>]"

и в задней части сделать так

foreach ($delete as $id => $val) {
    if($val=='checked'){
        $query="DELETE FROM documents WHERE id = '".$id."'";
        $result= mysqli_query($con, $query) or die("Invalid query");
    }
}
Понял, все, что мне нужно было сделать, это удалить оператор IF, и теперь это работает. Спасибо Maverick Johnson
Если я отображаю $ id, он показывает правильный идентификационный номер, но строка все равно не удаляется, но если я жестко закодирую идентификационный номер в sql, он работает. Есть идеи, что это за проблема? Maverick Johnson

Похожие вопросы