PHP得到mssql的存储过程的输出参数功能实现
时间:2018-12-30 分类:PHP 作者:编程之家
在开发过程中可能会遇到无法取得MSsql 存储过程的输出 参数,很多朋友都不知道该怎么办,本文将详细介绍PHP 得到mssql 的存储过程的输出 参数功能 实现,需要了解的朋友可以参考下 <div class="codetitle"><a style="CURSOR: pointer" data="4830" class="copybut" id="copybut4830" onclick="doCopy('code4830')"> 代码 如下:
<div class="codebody" id="code4830">
<?
$conn=ms
sql _connect("127.0.0.1","user","passwd");
ms
sql _select_db("mydb");
$stmt=ms
sql _init("pr_name",$conn);//
$a=50001;
ms
sql _bind($stmt,"RETVAL",$val,
sql VARCHAR); //用于直接返回return -103此类的值。
ms
sql _bind($stmt,"@ou
tvar ",$b,
sql VARCHAR,true);//用于返回在存储过程中定义的
输出 参数
ms
sql _bind($stmt,"@invar",$a,
sql INT4);
$result = ms
sql _execute($stmt,true);//不能返回结果集,只能得到
输出 参数
//$result = ms
sql _execute($stmt,false); //返回结果集
//$records=ms
sql _fetch_array($result);
//print_r($records);
//ms
sql _next_result($result);下
一个 结果集,当等于FALSE的时候下
一个 就是
输出 参数
echo $b;
echo $val;
?>
下面这些是从别的地方看到的。
小麻烦 :
我们按照惯例使用了
一个 MS
sql Server的存储过程procA,它给出了
一个 输出 参数nReturn,
而且返回了
一个 结果集。
在如何让
PHP 调用 这个procA的时候,我们遭遇了一点小麻烦。
鱼肉和熊掌不可兼得:
我们本来希望这样的
代码 能够既得到
输出 参数,又得到返回的结果集:
<div class="codetitle">
<a style="CURSOR: pointer" data="96544" class="copybut" id="copybut96544" onclick="doCopy('code96544')"> 代码 如下: <div class="codebody" id="code96544">
// 初始化要传进存储过程的参数们:
$nYear = 2004;
$nPageSize = 20;
$nPageNo = 1;
// Initializes a stored procedure:
$stmt = ms
sql _init("proc_stat_page",$db_ms
sql ->Link_ID);
// 绑定输入参数:
ms
sql _bind($stmt,"@nReturn",$nReturn,
sql INT4,TRUE);
ms
sql _bind($stmt,"@nYear",$nYear,
sql INT4);
ms
sql _bind($stmt,"@nPageSize",$nPageSize,"@nPageNo",$nPageNo,
sql INT4);
// 执行存储过程,得到QueryID:
$db_ms
sql ->Query_ID = ms
sql _execute($stmt,false);
虽然得到了结果集,但是,这样$nReturn参数是拿不到
输出 参数的。
如果把最后一句话改为:
$db_ms
sql ->Query_ID = ms
sql _execute($stmt,true);
输出 参数倒是拿到了,结果集又没有了。
好像是
一个 鱼肉和熊掌不可兼得的样子。
难道
PHP 连这个都做不到?
PHP 手册中也没有讲这个问题。
来自于
PHP 维护者的解释:
原本我们这种
调用 办法是
PHP 4.3版本之前肯定是
支持 的。
“但是,自从
PHP 4.3版本之后,”他们说,“为了能够兼容存储过程返回多个结果集,
PHP 改变这个特性。” “如果你不需要结果集,你应该设置ms
sql _execute的第二个可选参数为TRUE,这样ms
sql _execute
方法 之后你就可以得到
输出 参数了。” “如果你需要返回的结果集们,你应该为每
一个 结果集
调用 一次ms
sql _next_result。在最后
一个 结果集返回之后,你再
调用 ms
sql _next_result就会得到返回值FALSE,这时候,你就可以访问
输出 参数了。”
解决 :
在最后我们补上一句话 :
// After the last result has been returned the return value will have the value returned by the stored procedure.
ms
sql _next_result($db_ms
sql ->Query_ID);
立刻,魔法生效了:
PHP 填充了正确的
输出 参数到$nRetVal里。
原文地址:https://www.jb51.cc/php/26871.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。