首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >存储过程输出参数总是在PHP端给出0

存储过程输出参数总是在PHP端给出0
EN

Stack Overflow用户
提问于 2015-03-27 10:02:46
回答 1查看 860关注 0票数 1

存储过程在MS SQL Server上进行测试,并给出预期的输出(用于@AID)。但是,当从PHP @AID调用它时,总是给出0。我在这里做错什么了?

代码语言:javascript
复制
$stmt = mssql_init('UpdateActivity2', $conn);
mssql_bind($stmt, '@ParentActivity', $PP_ActivityID, SQLINT4, false, false, 8);
mssql_bind($stmt, '@ActivityName', $activityName, SQLVARCHAR, false, false, 255);
mssql_bind($stmt, '@ActivityType', $activityType, SQLINT4, false, false, 4);
mssql_bind($stmt, '@ActivityStatus', $activityStatus, SQLINT4, false, false,4);
mssql_bind($stmt, '@Descr', $descr, SQLVARCHAR, false, false, 255);
mssql_bind($stmt, '@RegistrationDate', $now, SQLVARCHAR, false, false, 255);
mssql_bind($stmt, '@FinishDate', $now, SQLVARCHAR, false, false, 255);
mssql_bind($stmt, '@Owner', $owner, SQLINT4, false, false, 4);
mssql_bind($stmt, '@SourceID', $sourceID, SQLINT4, false, false, 4);
mssql_bind($stmt, '@ContactID', $c, SQLINT4, false, false, 4);
mssql_bind($stmt, '@ActivityAddress',$a, SQLVARCHAR, false, false, 255);
mssql_bind($stmt, '@ExtReference', $e, SQLVARCHAR, false, false, 255);
mssql_bind($stmt, '@ResponsibleCompanyID', $e, SQLINT4, false, false, 4);
mssql_bind($stmt, '@AID', $h, SQLINT4, true);
$proc_result = mssql_execute($stmt);
echo $h;

@AID是存储过程的输出参数。但是,$h总是给出0。这是SP:

代码语言:javascript
复制
ALTER PROCEDURE [dbo].[UpdateActivity2]
@ParentActivity int,
@ActivityName varchar(150),
@ActivityType int,
@ActivityStatus int,
@Descr varchar(1024),
@RegistrationDate datetime,
@FinishDate datetime,
@Owner int,
@SourceID int,
@ContactID int,
@ActivityAddress varchar(150),
@ExtReference varchar(50),
@ResponsibleCompanyID int,
@AID int OUTPUT
AS
DECLARE @Value int;
EXEC @Value =  PG_GetSeq @Name = 'Activity'
PRINT('Printing')
PRINT(@Value)
INSERT INTO Activity(
                ActivityID, 
                ParentActivity, 
                ActivityName, 
                ActivityType, 
                ActivityStatus, 
                Descr, 
                RegistrationDate, 
                FinishDate, 
                Owner, 
                SourceID, 
                ContactID, 
                ActivityAddress, 
                ExtReference, 
                ResponsibleCompanyID
            )
            VALUES(
                @Value, 
                @ParentActivity, 
                @ActivityName, 
                @ActivityType, 
                @ActivityStatus, 
                @Descr, 
                @RegistrationDate, 
                @FinishDate, 
                @Owner, 
                @SourceID, 
                @ContactID, 
                @ActivityAddress, 
                @ExtReference, 
                @ResponsibleCompanyID
            )

    SELECT @AID = ActivityID FROM Activity WHERE ActivityID = @Value

Insert语句获得@Value的正确值,行也被正确插入。

EN

回答 1

Stack Overflow用户

发布于 2015-03-27 10:28:54

根据文献资料

如果存储过程返回参数或返回值,这些参数将在调用mssql_execute()之后可用,除非存储过程返回多个结果集。在这种情况下,使用mssql_next_result()来转换结果。当处理最后一个结果时,输出参数和返回值将可用。

您的print语句(可能还有行计数)干扰了结果集,因此您似乎有多个结果集,因此您需要调用mssql_next_result(),直到它返回false,然后才能访问输出参数。

或者,可以将参数true传递给参数$skip_results

代码语言:javascript
复制
mssql_execute($stmt, false);

这使您可以立即访问输出参数。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/29297963

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档