You have two errors in your code:
1) You forgot $q->fetch()
...
$q->execute(array($id));
$q->fetch(); // This line is required
2) But even after adding $q->fetch() you'll get this:
Fatal error: Cannot access private
property User::$name in ...
So, as you can see, PDO cannot access private members even if it is called inside class method.
Here is my solution:
...
$q->execute(array($id));
$q->setFetchMode(PDO::FETCH_ASSOC);
$data = $q->fetch();
foreach ($data as $propName => $propValue)
{
// here you can add check if class property exists if you don't want to
// add another properties with public visibility
$this->{$propName} = $propValue;
}
与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…