--TEST-- PDO Common: PDOStatement iterator --EXTENSIONS-- pdo --SKIPIF-- --FILE-- exec('CREATE TABLE test(id int NOT NULL PRIMARY KEY, val VARCHAR(10), grp VARCHAR(10))'); $db->exec('INSERT INTO test VALUES(1, \'A\', \'Group1\')'); $db->exec('INSERT INTO test VALUES(2, \'B\', \'Group2\')'); $SELECT = 'SELECT val, grp FROM test'; $stmt = $db->prepare($SELECT); $stmt->execute(); $stmt->setFetchMode(PDO::FETCH_NUM); foreach ($stmt as $data) { var_dump($data); } class Test { public $val; public $grp; function __construct($name = 'N/A') { echo __METHOD__ . "($name)\n"; } } unset($stmt); foreach ($db->query($SELECT, PDO::FETCH_CLASS, 'Test') as $data) { var_dump($data); } unset($stmt); $stmt = $db->query($SELECT, PDO::FETCH_CLASS, 'Test', array('WOW')); foreach($stmt as $data) { var_dump($data); } ?> --EXPECTF-- array(2) { [0]=> string(1) "A" [1]=> string(6) "Group1" } array(2) { [0]=> string(1) "B" [1]=> string(6) "Group2" } Test::__construct(N/A) object(Test)#%d (2) { ["val"]=> string(1) "A" ["grp"]=> string(6) "Group1" } Test::__construct(N/A) object(Test)#%d (2) { ["val"]=> string(1) "B" ["grp"]=> string(6) "Group2" } Test::__construct(WOW) object(Test)#%d (2) { ["val"]=> string(1) "A" ["grp"]=> string(6) "Group1" } Test::__construct(WOW) object(Test)#%d (2) { ["val"]=> string(1) "B" ["grp"]=> string(6) "Group2" }