从
PHP 5.3版起,PDO_
MysqL驱动程序已经被重新用于PDO_
MysqLND.它引入了对多个
查询的
支持.
虽然如果已经传递了多个SELECT查询,我不知道如何获取两个结果集.这两个查询都已被执行,不能仅仅是第二个被抛出.
$db->query("SELECT 1; SELECT 2;")->fetchAll(PDO::FETCH_ASSOC);
返回:
array(1) {
[0]=>
array(1) {
[1]=>
string(1) "1"
}
}
原来你需要使用PDOStatement :: nextRowset.
$stmt = $db->query("SELECT 1; SELECT 2;");
$stmt->nextRowset();
var_dump( $stmt->fetchAll(PDO::FETCH_ASSOC) );
这将返回第二个查询的结果.
这是一个奇怪的实现.如果多查询语句只会返回一个数组下的两个结果集,那肯定会更容易.但是,这个实现允许使用不同的FETCH styles来获取每个查询.