从PHP版本5.3开始,PDO_MYSQL驱动程序一直受到支持PDO_MYSQLND.它引入了对多个查询的支持.
但是,如果SELECT传递了多个查询,我无法弄清楚如何获取两个结果集.两个查询都已执行,不能是第二个查询刚刚被转储.
$db->query("SELECT 1; SELECT 2;")->fetchAll(PDO::FETCH_ASSOC);
Run Code Online (Sandbox Code Playgroud)
返回:
array(1) {
[0]=>
array(1) {
[1]=>
string(1) "1"
}
}
Run Code Online (Sandbox Code Playgroud)
Gaj*_*jus 22
事实证明你需要使用PDOStatement::nextRowset.
$stmt = $db->query("SELECT 1; SELECT 2;");
$stmt->nextRowset();
var_dump( $stmt->fetchAll(PDO::FETCH_ASSOC) );
Run Code Online (Sandbox Code Playgroud)
这将返回第二个查询的结果.
这有点奇怪的实现.如果多查询语句只返回一个数组下的两个结果集,那肯定会更容易.但是,优点是该实现允许使用不同的FETCH样式获取每个查询.
| 归档时间: |
|
| 查看次数: |
14827 次 |
| 最近记录: |