理由はわかりませんが、この準備されたクエリが機能しません: 次の php コードは正しい (警告や通知はありません) が、対応するデータは更新されません。同様の更新では、データベースは正しく更新されますが、このテーブルでは更新されません。
<?php
error_reporting(E_ALL);
ini_set('display_errors', 'On');
$pdo = new PDO('mysql:dbname=test;host=localhost', 'root', '');
$sql = 'UPDATE `ml_user` SET `username` = :username, `password` = :password, `email` = :email, `active` = :active, `last_login` = :last_login WHERE `id_user` = :id_user';
$sth = $pdo->prepare($sql);
var_dump($sth); // object(PDOStatement)#39 (1) { ["queryString"]=> string(165) "UPDATE `ml_user` SET `username` = :username, `password` = :password, `email` = :email, `active` = :active, `last_login` = :last_login WHERE `id_user` = :id_user" }
$datas = array(
':id_user' => 1, ':username' => 'my username',
':password' => 'ae25ff724d069dcb1a7fff05616ad6abc1',
':email' => 'username@example.com',
':active' => 1, ':last_login' => 1382990654,
);
$res = $sth->execute($datas);
var_dump($res); // bool(true)
SQL テーブル
CREATE TABLE `ml_user` (
`id_user` int(11) NOT NULL AUTO_INCREMENT,
`active` tinyint(1) NOT NULL DEFAULT '0',
`email` varchar(127) NOT NULL,
`username` varchar(32) NOT NULL DEFAULT '',
`password` char(50) NOT NULL,
`logins` int(10) unsigned NOT NULL DEFAULT '0',
`last_login` int(10) unsigned DEFAULT NULL,
PRIMARY KEY (`id_user`),
UNIQUE KEY `uniq_username` (`username`),
UNIQUE KEY `uniq_email` (`email`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8