exec("SET names GB2312"); $stmt = $db->execute("call xyyh_">
当前位置:Gxlcms > PHP教程 > 请教一个调用带参数的MSSQL存储过程,返回结果集的问题

请教一个调用带参数的MSSQL存储过程,返回结果集的问题

时间:2021-07-01 10:21:17 帮助过:17人阅读

代码如下:
if ($debug==1){echo "数据库连接成功!
";}
try{
$db->exec("SET names GB2312");
$stmt = $db->execute("call xyyh_stock_inventory 'R99.33569-0000-00'");
// $stmt->bindParam(1, $FNumber);
// 调用存储过程
$stmt->execute();
}
catch(pdoexception $e){
print '执行失败: '.$e->getMessage();
exit();
}
我调 用的MSSQL存储过程已调试好,在SQL的查询分析中可以返回想到的结果,请教如何写代码过能在PHP中返回结果集?
网上查了相应的资料,笨了点,没弄明白如果得到想要的结果集。


回复讨论(解决方案)

$stmt->execute();
返回了什么?

PDOStatement Object ( [queryString] => call xyyh_stock_inventory ? )

重新修改了代码,
if ($debug==1){echo "数据库连接成功!
";}
try{
$db->exec("SET names GB2312");
$stmt=$db->prepare("call xyyh_stock_inventory :FNumber");
$stmt->bindParam(":FNumber", $FNumber, PDO::PARAM_STR);
if ($stmt->execute()){echo "执行成功!
";}else{echo "执行不成功!
";}
}
catch(pdoexception $e){
print '执行失败: '.$e->getMessage();
exit();
}
并执行,结果显示在 $stmt->execute()处执行 不成功

最算是找到了解决目前用的办法

if ($debug==1){echo "数据库连接成功!
";} try{ $stmt = $db->prepare('exec xyyh_stock_trantype_1_24 ?'); $stmt->bindParam(1,$FNumber); $stmt->execute(); if ($debug==1){ print_r($stmt);echo "
";} $i=1; echo ""; do { $rowset = $stmt->fetchall(PDO::FETCH_ASSOC); if ($rowset){ if ($debug==1){print_r($rowset);echo "
";} if ($debug==1){print_r($rowset[$i]);echo "
";} foreach ($rowset as $row) { echo ""; echo ""; echo ""; } } $i++; } while ($stmt->nextRowset()); echo "
日期单据编码物料编码物料名称计量单位业务类型异动数量
".$row["FDate"]."".$row["FBillNo"]."".$row["FNumber"]."".$row["FName"]."".$row["FUnitName"]."".$row["FTranType"]."".$row["FQty"]."
"; } catch(pdoexception $e){ print '执行失败: '.$e->getMessage(); exit(); }


先凑合用一下

人气教程排行