使用ID从数据库中删除一行

时间:2012-05-17 23:13:38

标签: php mysqli

我在使用MSQLI从屏幕上删除记录时遇到问题。 在这里你可以看到我正在使用的代码。

<?php
        include_once("assets/classes/connection.php");
        include_once("assets/classes/article.class.php");
        while($test = $allArticles->fetch_assoc())
            {
                if($test['titel']=="")
                {
                    echo "<div class='zonderfoto'>";
                    echo "<h5>"."geen titel hier, aparte opmaak geslaagd" . "<br /></h1>";
                    echo "<p>" . $test['article'] . "</p>";

                    echo "<input type='submit' name='verwijderee' value='verwijder'>";

                    echo "</div>";
                }
                else
                {
                    echo "<div class='metfoto'>";
                    echo "<h1>".$test['titel'] . "<br /></h1>";
                    echo "<p>" . $test['article'] . "</p>";
                    echo "<form method='post' action=''>";
                    echo "<input type='submit' name='verwijder' value='verwijder'>";
                    echo "</form>";
                    echo "<h1>".$test['id']."</h1>";
                    echo "</div>";


                }
            }
        $vArticle = new Article;
        $vArticle -> Key = $test['id'];
        if (isset($_POST['verwijder']))
        {
            $vArticle -> deleteArticle();
            echo ("shit");
        }
        ?>

我正在使用while函数在屏幕上打印所有数据库记录。 if函数只是一个给css设计的函数,仅此而已。使用删除按钮我想从屏幕上删除记录。使用$ test ['id'] varbele,您将收到DB中记录的ID

好的,这是我班上的代码。

public function deleteArticle()
{
    include("connection.php");
    $sSql = "DELETE FROM tblArticles WHERE id = '".$this->m_sKey."'";

        if (!$mysqli -> query($sSql))
        {
            throw new Exception("Something went wrong");
        }
}

修改

键有问题,我用title =“”替换了where语句,所以我删除了数据库中的一个标题,当我点击删除然后,他删除了一行,但这是没有在运行时发生。所以我点击删除,删除一行,但内容只有页面刷新消失。解决方案是使用ajax?

1 个答案:

答案 0 :(得分:0)

public function deleteArticle()
{
    include("connection.php");
    $sSql = "DELETE FROM tblArticles WHERE id = '".$this->m_sKey."'";
    $mysqli->query($sSql);
    $aff_rows = $mysqli->affected_rows;
    if ($aff_rows){
        print("Affected rows (DELETE): %d\n", $aff_rows);
    }
    else{
        print("Nothong Happend ?");
        if ($err = $mysqli->error){
              print("Error: %s\n", $err);
        }
    }
}