用魔术方法使用PDO::FETCH_CLASS


Using PDO::FETCH_CLASS with Magic Methods

我有一个类,它使用魔术方法来存储属性。下面是一个简化的例子:

class Foo {
    protected $props;
    public function __construct(array $props = array()) {
        $this->props = $props;
    }
    public function __get($prop) {
        return $this->props[$prop];
    }
    public function __set($prop, $val) {
        $this->props[$prop] = $val;
    }
}

PDOStatement执行后,我试图为它的每个数据库行实例化这个类的对象,如下所示(不起作用):

$st->setFetchMode(PDO::FETCH_CLASS, 'Foo');
foreach ($st as $row) {
    var_dump($row);
}

问题是PDO::FETCH_CLASS在设置属性值时似乎不会触发类上神奇的__set()方法。

如何使用PDO实现所需效果

PDO的默认行为是在调用构造函数之前设置属性。当您在调用构造函数后设置获取模式以设置属性时,请在位掩码中包含PDO::FETCH_PROPS_LATE,这将导致对未定义的属性调用__set魔术方法。

$st->setFetchMode(PDO::FETCH_CLASS | PDO::FETCH_PROPS_LATE, 'Foo');

或者,创建一个实例并提取(即将提取模式设置为PDO::FETCH_INTO)。