Ano PDO
může načíst dvě (nebo více) sad řádků, pokud to databáze, kterou používáte, podporuje. Myslím, že MS SQL Server a MySQL oba tuto funkci podporují, ale v době psaní SQLite ne.
Požadovaná funkce je PDOStatement::nextRowset
Takže ve vašem příkladu výše byste mohli udělat něco jako;
$sth = $dbh->prepare("SELECT * FROM tb1 WHERE cond1;
SELECT * FROM tb2 WHERE cond2");
$sth->execute();
$rowset1 = $sth->fetchAll();
$sth->nextRowset();
$rowset2 = $sth->fetchAll();
print_r($rowset1);
print_r($rowset2);
Je naprosto rozumné, aby jedna uložená procedura vracela více než jednu sadu řádků.