使用复选框从mysql中删除多行?

时间:2010-08-02 19:52:42

标签: php mysql

如果此问题的副本存在,我想道歉。我试图找到并且可以在这里找到任何可以解决我问题的东西..

我使用表单获取输入并在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复选框的工作原理以及如何使用它来删除多个记录。我想知道我必须为它编写什么额外的代码,如果有人向我解释额外的代码,我会非常感激..

谢谢..

3 个答案:

答案 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才能生效,但您知道;)