select * from table;
select * from table1;
out $id;
如上:存储过程返回两个结果集和一个输出参数,如何在php中获得这两个结果集和输出参数?
回复讨论(解决方案) 一个个读取
见 pdostatement::nextrowset 方法说明
一个个读取
见 pdostatement::nextrowset 方法说明
如果只有多个集合我知道,但是有输出参数,如下
$stmt = $db->prepare(call pro_test(:name,@sp_result);); $stmt->execute (array(':name'=>$name)); $outputarray = $db->query(select @sp_result)->fetch(pdo::fetch_assoc); print_r($outputarray[@sp_result]);
存储过程返回一个集合,输出参数需要查询一次,但是到了这一步就出错了
$outputarray = $db->query(select @sp_result)->fetch(pdo::fetch_assoc);
error: soap-env:server, string: call to a member function fetch() on a non-object
我猜应该是之前存储过程返回了个结果,再查一个就出错了,如何解决?
这是手册上的示例 $sql = 'call multiple_rowsets()';$stmt = $conn->query($sql);$i = 1;do { $rowset = $stmt->fetchall(pdo_fetch_num); if ($rowset) { //想想这里为什么要先判断一下 printresultset($rowset, $i); } $i++;} while ($stmt->nextrowset());
这是手册上的示例 $sql = 'call multiple_rowsets()';$stmt = $conn->query($sql);$i = 1;do { $rowset = $stmt->fetchall(pdo_fetch_num); if ($rowset) { //想想这里为什么要先判断一下 printresultset($rowset, $i); } $i++;} while ($stmt->nextrowset());
你可能理解错我的意思了,我需要存储过程的结果集和存储过程返回的参数,不过已经解决了,还是去官网看的,谢谢关注,·· 后面还有很多问题
note for mysql: to use input/output parameters for stored procedures with pdo use pdo.query() statement. for example: query(cast somestoredprocedure($someinparameter1, $someinparameter2, @someoutparameter)); $dbh->query(select @someoutparameter); ?> or, if you want very much to use pdo.prepare(), insert select @someoutparameter in your stored procedure and then use: prepare(cast somestoredprocedure(?, ?)); $stmt ->execute(array($someinparameter1, $someinparameter2)); ?>