如果此问题的副本存在,我想道歉。我试图找到并且可以在这里找到任何可以解决我问题的东西..
我使用表单获取输入并在mysql数据库中更新它,然后检索html表单中的记录,并定义了通过超链接单独删除记录的代码。但是我想做更多,我想使用复选框删除多个记录。
我的代码是这样的。
<?php
//include connection string
include('connection.php');
?>
<form action="<?php $_SERVER['PHP_SELF'] ?>" method="post"/>
Username : <input type="text" name="user"/><br />
Password : <input type="password" name="pass"/><br />
<input type="submit" name="submit" value="Send"/>
</form>
<?php
// query to insert into database
if(isset($_POST['user']) && isset($_POST['pass'])) {
$user = empty($_POST['user']) ? die(mysql_error()) : mysql_escape_string($_POST['user']);
$pass = empty($_POST['pass']) ? die(mysql_error()) : sha1(mysql_escape_string($_POST['pass']));
$query = "INSERT INTO users(name, pass) VALUES ('$user', '$pass')";
$result = mysql_query($query) or die(mysql_error());
}
if(isset($_GET['id'])) {
//query to delete the records
$query = "DELETE FROM users WHERE id = " . intval($_GET['id']);
$result = mysql_query($query);
}
//query to retrieve records
$query = "SELECT * FROM users";
$result = mysql_query($query);
if(mysql_num_rows($result) > 0 ) {
echo "<table cellpadding=10 border=1>";
while ($row = mysql_fetch_row($result)) {
echo "<tr>";
echo "<td>" . $row[0] . "</td>";
echo "<td>" . $row[1] . "</td>";
echo "<td>" . $row[2] . "</td>";
echo "<td><a href = " . $_SERVER['PHP_SELF'] . "?id=" .$row[0] . ">delete</a>";
echo "</tr>";
}
echo "</table>";
}
?>
我希望你知道我是编程世界的新手,我不太确定html复选框的工作原理以及如何使用它来删除多个记录。我想知道我必须为它编写什么额外的代码,如果有人向我解释额外的代码,我会非常感激..
谢谢..答案 0 :(得分:1)
这可能是另一种形式的好时机:
<?php
// query to insert into database ...
// ... etc...
if(isset($_POST["formDeleteSelected"])) {
//query to delete the records
$query = "DELETE FROM users WHERE id IN (" . implode(", ",$_POST["rowid"]) . ")";
$result = mysql_query($query);
header("Location: mycode.php"); // just so 'refresh' doesn't try to run delete again
exit();
}
?>
<form action="<?php $_SERVER['PHP_SELF'] ?>" method="post">
<?php
//query to retrieve records
$query = "SELECT * FROM users";
$result = mysql_query($query);
if(mysql_num_rows($result) > 0 ) {
echo "<table cellpadding=10 border=1>";
while ($row = mysql_fetch_row($result)) {
echo "<tr>";
echo "<td><input type="checkbox" name="rowid[]" value=\"" . $row[0] . "\" /></td>";
echo "<td>" . $row[0] . "</td>";
echo "<td>" . $row[1] . "</td>";
echo "<td>" . $row[2] . "</td>";
echo "</tr>";
}
echo "</table>";
}
?>
<input type="submit" name="formDeleteSelected" text="Delete Selected" />
</form>
或喜欢的东西(我实际上没有尝试过那段代码,所以可能会有拼写错误)。另请注意,您应该确保清理SQL注入的任何表单/获取输入(有关其他Stack Overflow问题的大量信息)。
答案 1 :(得分:0)
首先,您需要一个复选框和要删除的ID:
<input id="delete" type="checkbox" name="delete" /><label for="delete">Delete user</label>
<input type="hidden" name="user_id" value="12345" />
然后,您可以测试是否已设置复选框,然后手动设置GET参数以重用现有代码:
if(isset($_POST['delete'])){
$_GET['id'] = $_POST['user_id'];
}
这不是最优雅的解决方案,而是一个非常简单的解决方案。
答案 2 :(得分:0)
尝试使用ID列表
的SQL查询... WHERE id=$sentIds[0] OR id=$sentIds[1] OR ...
或使用设定操作
... WHERE id IN ($i1,$i2 ... );
您确定必须在表单中发送ID才能生效,但您知道;)