mssql_bind出错问题

本文介绍使用PHP连接MSSQL Server 2005并调用存储过程时遇到的问题及解决办法。作者尝试调用一个计算特定年龄学生数量的存储过程,但在调试过程中遇到了错误,指出只有变量可以通过引用传递。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天玩着没事,用php连接mssql server 2005的存储过程,出现小的错误

代码如下,

$host="localhost";
	$user='sa';
	$password='01211107';
	$dbname='book';
	$link=mssql_connect($host,$user,$password) or die('link failure');
	if($link){
		mssql_select_db('book');
	}
	$stmt=mssql_init('cheng',$link);
	mssql_bind($stmt,'@ager', 25 ,SQLINT1,false,false,3);
	$sp=mssql_execute($stmt);
	while($row=mssql_fetch_assoc($sp)){
		print_r($row);
	}

存储过程为:

set ANSI_NULLS ON
set QUOTED_IDENTIFIER ON
go
ALTER procedure [dbo].[cheng]
@ager smallint
as
	begin 
		select count(*) as cou from student where age=@ager
	end

  

在xdebug调试下,提示

Fatal error: Only variables can be passed by reference in D:\php5\test.php on line 16

只有变量可以通过引用传递的意思

mssql_bind(),第三个参数必须是变量

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值