0

問題は :soundid POST から受信した soundid='soundidfromPOST' を手動で入力すると、行が更新されますが、soundid=: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!';
    }
}
4

1 に答える 1

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);
于 2013-05-14T21:37:14.837 に答える