sql >> データベース >  >> RDS >> Mysql

PHPMysql削除クエリが正しく機能していません

    id="delete"を設定したことが原因である可能性があります 。通常、id属性値は複製されません。

    echo "<td><form action='delete_prod.php' id='delete' method='get'>";
    echo "<button type='submit' form = 'delete' class='btn btn-default' name='delete'>Delete</button>";
    

    送信ボタンは最初のIDを取得し、最初の非表示の入力を取得します。

    または、次のようにボタンを考案して、マーカーとして使用することもできます。

    各フォームを印刷する必要はありません!。テーブルで包むだけです:

    echo "<form action='delete_prod.php' id='delete' method='get'>";
    
    echo '<table>';
    while($row = mysqli_fetch_assoc($result)) {
        $prod_id = $row['prod_id'];
        echo "<tr>";
            echo "<td>".$count."</td>";
            echo "<td>".$row['prod_id']."</td>";
            echo "<td>".$row['prod_name']."</td>";
            echo "<td>".$row['prod_price']."</td>";
            echo "<td>";
            // each id is assigned to each button, so that when its submitted you get the designated id, the one that you clicked
            echo "<button type='submit' value='$prod_id' class='btn btn-default' name='delete'>Delete</button>";
            echo "</td>";
        echo '</tr>';
    }
    
    echo '</table>';
    echo '</form>';
    

    次に、PHP処理で:

    if(isset($_GET['delete'])) // as usual
    {
        include "connection.php";
        $prod_id = $_GET['delete']; // get the id
        // USE PREPARED STATEMENTS!!!
        $del="DELETE FROM products WHERE prod_id = ?";
        $delete = $link->prepare($del);
        $delete->bind_param('i', $prod_id);
        $delete->execute();
        // don't echo anything else, because you're going to use header
        if($delete->affected_rows > 0) {
            header('location:show_db.php');
        } else {
            echo 'Sorry delete did not push thru!';
        }
    }
    


    1. MySQL JOIN、GROUP BY、ORDER BY

    2. 挿入された行の行データの取得(Mysql、PHP、mysqli)

    3. MySQLで列が空かnullかどうかを確認するにはどうすればよいですか?

    4. NHibernate.Mapping例外。 Namespace.classNameの永続性はありません