PDO PHP更新脚本无法正常工作

时间:2016-01-18 18:36:08

标签: php mysql pdo

我搜索了stackoverflow和其他来源,但我似乎无法找到阻止我的PHP脚本工作的问题。

查看echo_sql。它生成一个健康的更新语句,在运行时更新数据库没有问题。这是一个示例:

update waste set waste_name=1 where id =82;

但是,运行脚本时,它不会对数据库应用更改。这是脚本:

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

    try {

        $waste_id = $_POST['waste_id'];
        $sql = new db;
        $sql->beginTransaction();

        $waste_name = $_POST['waste_name'];

        $sql->query("update waste set waste_name=:waste_name where id =:waste_id;");

        $echo_sql = "update waste set waste_name=$waste_name where id =$waste_id;";
        echo $echo_sql;

        $sql->bind(':waste_name', $waste_name);

        $sql->execute();

        $sql->endTransaction();

    } catch (Exception $e) {
        $sql->rollBack();
        echo "Failed: " . $e->getMessage();
    }

}

其他详情:

errorCode() = 00000

数据库类:

class db
{

    private $stmt;
    private $dbc;

    public function __construct()
    {
        $u = "root";
        $p = "";
        try {
            $this->dbc = new PDO('mysql:host=127.0.0.1;dbname=wimsdb', $u, $p);
            $this->dbc->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
        } catch (PDOException $e) {
            $e->getMessage();
        }
    }

    public function bind($param, $value, $type = NULL)
    {
        $this->stmt->bindParam($param, $value, $type);
    }

    public function beginTransaction()
    {
        return $this->dbc->beginTransaction();
    }

    public function rollBack()
    {
        return $this->dbc->rollBack();
    }

    public function endTransaction()
    {
        return $this->dbc->commit();
    }

    public function cancelTransaction()
    {
        return $this->dbc->rollBack();
    }


    public function execute()
    {
        try {
            return $this->stmt->execute();
        } catch (PDOException $e) {
            return $e->errorInfo;
        }
    }

    public function errorCode()
    {
        return $this->stmt->errorCode();
    }

    public function query($query)
    {
        $this->stmt = $this->dbc->prepare($query);
    }
}

请就如何解决此问题提出建议。

2 个答案:

答案 0 :(得分:2)

您还需要绑定:waste_id

    $waste_id = $_POST['waste_id'];
    $sql = new db;
    $sql->beginTransaction();

    $waste_name = $_POST['waste_name'];

    $sql->query("update waste set waste_name=:waste_name where id =:waste_id;");


    $sql->bind(':waste_name', $waste_name);
    $sql->bind(':waste_id', $waste_id);

如果您遇到这样的问题,您的错误检查应返回一条有意义的消息,告知您错误的位置以及可能 错误的位置。您应该能够检查错误日志以获取详细信息和/或在测试期间将它们输出到您的屏幕。

答案 1 :(得分:0)

添加waste_id。为了避免丢失参数,我喜欢将参数运算符放入execute方法中。 bind方法可以在代码中的任何地方定义,因此我必须查看代码并确保waste_id绑定未在其他地方定义。当它在执行方法中时,您可以快速查看在那里定义的所有参数......它也有点简洁......但两者都有它们的用途。

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

try {

    $waste_id = $_POST['waste_id'];
    $sql = new db;
    $sql->beginTransaction();

    $waste_name = $_POST['waste_name'];

    $sql->query("update waste set waste_name=:waste_name where id =:waste_id;");

    $echo_sql = "update waste set waste_name=$waste_name where id =$waste_id;";
    echo $echo_sql;

    //just because I like this syntax for being concise and clear :)
    $sql->execute(array(
        'waste_id'   => $waste_id,
        'waste_name' => $waste_name
    ));

    $sql->endTransaction();

} catch (Exception $e) {
    $sql->rollBack();
    echo "Failed: " . $e->getMessage();
}