0

内部にチェックボックスがある MySQL データベースのテーブルに結果を表示しています。ユーザーが 5 行にチェックを入れて削除ボタンをクリックした場合、どうすれば多くの行を同時に削除できますか?

4

3 に答える 3

2

HTML:

<form method="post">

    <input type="checkbox" name="id[]" value="123" /> Element 1 <br/>
    <input type="checkbox" name="id[]" value="5434" /> Element 2 <br/>
    <input type="checkbox" name="id[]" value="24" /> Element 3 <br/>
    <input type="checkbox" name="id[]" value="76" /> Element 4 <br/>

    <input type="submit" value="delete" />

</form>

PHP:

if ( $_SERVER['REQUEST_METHOD'] == 'POST' ) {

  $ids = array_walk($_POST['id'], 'intval');
  mysql_query('DELETE FROM table WHERE id IN (' . implode(',', $ids) . ')');

}

PS ポイントが欲しい!

于 2011-03-02T16:59:16.227 に答える
1

PHP コードは提供しませんが、次のような SQL クエリを作成すると問題が解決します。

DELETE FROM foo WHERE id IN ( … );

詳しくはマニュアルをご覧ください。

于 2011-03-02T16:59:31.977 に答える
1

このような PDOStatement で

$statement = "DELETE FROM table WHERE id = ?";
$conn = new PDO($dns,$user,$pass);
$conn->beginTransaction();
$query = $conn->prepare($statement);
foreach($params as $p){ //$params are your checked id's
    $query->bindParam(1,$p);
    if($query->execute()){
        echo "ok";
    }else{
        $conn->rollBack();
        exit("Error");
    }
}
$conn->commit();
于 2011-03-02T17:02:59.613 に答える