PHP得到mssql的存储过程的输出参数功能实现


Posted in PHP onNovember 23, 2012

在开发过程中可能会遇到无法取得MSSQL存储过程的输出参数,很多朋友都不知道该怎么办,本文将详细介绍PHP得到mssql的存储过程的输出参数功能实现,需要了解的朋友可以参考下

<? 
$conn=mssql_connect("127.0.0.1","user","passwd"); 
mssql_select_db("mydb"); 
$stmt=mssql_init("pr_name",$conn);// 
$a=50001; 
mssql_bind($stmt,"RETVAL",$val,SQLVARCHAR); //用于直接返回return -103此类的值。 
mssql_bind($stmt,"@outvar",$b,SQLVARCHAR,true);//用于返回在存储过程中定义的输出参数 
mssql_bind($stmt,"@invar",$a,SQLINT4); 
$result = mssql_execute($stmt,true);//不能返回结果集,只能得到输出参数 
//$result = mssql_execute($stmt,false); //返回结果集 
//$records=mssql_fetch_array($result); 
//print_r($records); 
//mssql_next_result($result);下一个结果集,当等于FALSE的时候下一个就是输出参数 
echo $b; 
echo $val; 
?>

下面这些是从别的地方看到的。
小麻烦
我们按照惯例使用了一个MS Sql Server的存储过程procA,它给出了一个输出参数nReturn,
而且返回了一个结果集。
在如何让PHP调用这个procA的时候,我们遭遇了一点小麻烦。
鱼肉和熊掌不可兼得:
我们本来希望这样的代码能够既得到输出参数,又得到返回的结果集:
// 初始化要传进存储过程的参数们: 
$nYear = 2004; 
$nPageSize = 20; 
$nPageNo = 1; 
// Initializes a stored procedure: 
$stmt = mssql_init("proc_stat_page", $db_mssql->Link_ID); 
// 绑定输入参数: 
mssql_bind($stmt, "@nReturn", $nReturn, SQLINT4, TRUE); 
mssql_bind($stmt, "@nYear", $nYear, SQLINT4); 
mssql_bind($stmt, "@nPageSize", $nPageSize, SQLINT4); 
mssql_bind($stmt, "@nPageNo", $nPageNo, SQLINT4); 
// 执行存储过程,得到QueryID: 
$db_mssql->Query_ID = mssql_execute($stmt,false);

虽然得到了结果集,但是,这样$nReturn参数是拿不到输出参数的。
如果把最后一句话改为:
$db_mssql->Query_ID = mssql_execute($stmt,true);
输出参数倒是拿到了,结果集又没有了。
好像是一个鱼肉和熊掌不可兼得的样子。
难道PHP连这个都做不到?PHP手册中也没有讲这个问题。
来自于PHP维护者的解释:
原本我们这种调用办法是PHP 4.3版本之前肯定是支持的。
“但是,自从PHP 4.3版本之后,”他们说,“为了能够兼容存储过程返回多个结果集,PHP改变这个特性。”

“如果你不需要结果集,你应该设置mssql_execute的第二个可选参数为TRUE,这样mssql_execute方法之后你就可以得到输出参数了。”

“如果你需要返回的结果集们,你应该为每一个结果集调用一次mssql_next_result。在最后一个结果集返回之后,你再调用mssql_next_result就会得到返回值FALSE,这时候,你就可以访问输出参数了。”
解决:
在最后我们补上一句话
// After the last result has been returned the return value will have the value returned by the stored procedure.
mssql_next_result($db_mssql->Query_ID);
立刻,魔法生效了:
PHP填充了正确的输出参数到$nRetVal里。

PHP 相关文章推荐
PHP面向接口编程 耦合设计模式 简单范例
Mar 23 PHP
PHP中的函数-- foreach()的用法详解
Jun 24 PHP
php实现12306火车票余票查询和价格查询(12306火车票查询)
Jan 14 PHP
php检测useragent版本示例
Mar 24 PHP
PHP查询快递信息的方法
Mar 07 PHP
php生成唯一数字id的方法汇总
Nov 18 PHP
PHP实现小偷程序实例
Oct 31 PHP
Zend Framework校验器Zend_Validate用法详解
Dec 09 PHP
PHP检测数据类型的几种方法(总结)
Mar 04 PHP
php变量与JS变量实现不通过跳转直接交互的方法
Aug 25 PHP
PHP递归实现快速排序的方法示例
Dec 18 PHP
PHP SESSION跨页面传递失败解决方案
Dec 11 PHP
php实现文件下载更能介绍
Nov 23 #PHP
php 定义404页面的实现代码
Nov 19 #PHP
php中的注释、变量、数组、常量、函数应用介绍
Nov 16 #PHP
apache php模块整合操作指南
Nov 16 #PHP
php获取用户IPv4或IPv6地址的代码
Nov 15 #PHP
屏蔽机器人从你的网站搜取email地址的php代码
Nov 14 #PHP
PHP中文分词 自动获取关键词介绍
Nov 13 #PHP
You might like
法压式咖啡之制作法
2021/03/03 冲泡冲煮
PHP中显示格式化的用户输入
2006/10/09 PHP
PHP新手上路(十)
2006/10/09 PHP
php操作SVN版本服务器类代码
2011/11/27 PHP
PHP跳转页面的几种实现方法详解
2013/06/08 PHP
php生成QRcode实例
2014/09/22 PHP
ThinkPHP基于PHPExcel导入Excel文件的方法
2014/10/15 PHP
PHP生成图片验证码功能示例
2017/01/12 PHP
让您的菜单不离网站
2006/10/03 Javascript
用Javascript同时提交多个Web表单的方法
2009/12/26 Javascript
ASP.NET jQuery 实例15 通过控件CustomValidator验证CheckBoxList
2012/02/03 Javascript
mailto的使用技巧分享
2012/12/21 Javascript
js文件Cookie存取值示例代码
2014/02/20 Javascript
基于JS分页控件实现简单美观仿淘宝分页按钮效果
2016/11/07 Javascript
详谈Ajax请求中的async:false/true的作用(ajax 在外部调用问题)
2017/02/10 Javascript
BootStrap 标题设置跨行无效的解决方法
2017/10/25 Javascript
jQuery-ui插件sortable实现自由拖动排序
2018/12/01 jQuery
初试vue-cli使用HBuilderx打包app的坑
2019/07/17 Javascript
谈谈IntersectionObserver懒加载的具体使用
2019/10/15 Javascript
vue中在vuex的actions中请求数据实例
2019/11/08 Javascript
JavaScript动态生成表格的示例
2020/11/02 Javascript
python求斐波那契数列示例分享
2014/02/14 Python
Python素数检测实例分析
2015/06/15 Python
Python实现将文本生成二维码的方法示例
2017/07/18 Python
python用户管理系统
2018/03/13 Python
python 将有序数组转换为二叉树的方法
2019/03/26 Python
Python操作Mongodb数据库的方法小结
2019/09/10 Python
CSS3实现可关闭的下拉手风琴菜单效果
2015/08/31 HTML / CSS
Genny意大利官网:意大利高级时装品牌
2020/04/15 全球购物
Linux中如何设置Java环境变量(Ubuntu)
2016/07/24 面试题
优秀演讲稿范文
2013/12/29 职场文书
30年同学聚会感言
2014/01/30 职场文书
观看建国大业观后感
2015/06/01 职场文书
养成教育主题班会
2015/08/13 职场文书
先进教师个人主要事迹材料
2015/11/03 职场文书
sql字段解析器的实现示例
2021/06/23 SQL Server