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来获取每个查询.

dawei

【声明】:淮南站长网内容转载自互联网,其相关言论仅代表作者个人观点绝非权威,不代表本站立场。如您发现内容存在版权问题,请提交相关链接至邮箱:bqsm@foxmail.com,我们将及时予以处理。