繁体   English   中英

PDO多个查询

[英]PDO multiple queries

从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样式获取每个查询。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM