简单的PDO更新无效

时间:2013-05-14 19:38:48

标签: php pdo

问题出现了:如果我手动键入soundid ='soundidfromPOST'从POST收到声音,则行更新,但是声音=:soundid ...没有。为什么呢?

PDO :: ATTR_ERRMODE到PDO :: ERRMODE_EXCEPTION并启用了error_reporting。

public function save($args) {
    $userid = Controller::getUserConnection();
    if ($userid) {
        $soundid = $_POST['soundid'];
        $track_title = $_POST['track_title'];
        $track_artist = $_POST['track_artist'];
        $track_album = $_POST['track_album'];
        $track_genre = $_POST['track_genre'];
        $track_description = $_POST['track_description'];
        $played = 1;
        $statement = $this->_db->prepare("UPDATE sounds SET title=:track_title, artist=:track_artist, album=:track_album, genre_id=:track_genre, description=:track_description, played=:played WHERE soundid=:soundid AND userid=:userid AND ip=:ip");
        $statement->bindParam(':soundid',$soundid,PDO::PARAM_STR);
        $statement->bindParam(':userid',$userid,PDO::PARAM_INT);
        $statement->bindParam(':track_title',$track_title,PDO::PARAM_STR);
        $statement->bindParam(':track_artist',$track_artist,PDO::PARAM_STR);
        $statement->bindParam(':track_album',$track_album,PDO::PARAM_STR);
        $statement->bindParam(':track_genre',$track_genre,PDO::PARAM_INT);
        $statement->bindParam(':track_description',$track_description,PDO::PARAM_STR);
        $statement->bindParam(':ip',$_SERVER['REMOTE_ADDR'],PDO::PARAM_STR);
        $statement->bindParam(':played',$played,PDO::PARAM_INT);
        $statement->execute();
        echo 'saved!';
    }
}

1 个答案:

答案 0 :(得分:2)

我会执行以下操作以使其更清晰,因为您不需要明确地绑定所有内容(请注意我没有使用所有变量):

将要在查询中使用的所有发布数据分配给数组:

$data = array(
   'userid' => $userid,
   'sounddid' => $_POST['soundid'],
   'track_title' => $_POST['track_title'],
   'track_artist' => $_POST['track_title'],
   'ip' => $_SERVER['REMOTE_ADDR'],
);

写下你的查询:

$sth = $this->_db->prepare("
    UPDATE sounds SET 
    title = :track_title, 
    artist = :track_artist
    WHERE soundid = :soundid 
    AND userid = :userid 
    AND ip = :ip
");

传入要执行的数据数组:

$result = $sth->execute($data);