我正在尝试使用bindParam(PHP PDO)获取输出。 PHP PDO 库是 FreeTDS for MS SQL 驱动程序。无论我做什么,我似乎都无法按照 php.net 上的建议在绑定参数中获得“输出”。我已经验证我可以调用 EXEC 并返回结果集(使用选择),但 OUTPUT 参数永远不会改变。
PHP 代码。 $this->db 是一个 PDO 对象
$stmt = $this->db->prepare("EXEC ".$this->db_schema."[".$this->procedure."] :error_num, :error_msg");
$error_num = 0;
$error_msg = '';
$stmt->bindParam(':error_num', $error_num, PDO::PARAM_INT|PDO::PARAM_INPUT_OUTPUT);
$stmt->bindParam(':error_msg', $error_msg, PDO::PARAM_STR|PDO::PARAM_INPUT_OUTPUT, 2000);
$stmt->execute();
var_dump($stmt);
echo "\nerror_num: $error_num";
echo "\nerror_msg: $error_msg\n\n";
用于测试输出的存储过程
USE [NGCustom]
GO
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
ALTER PROCEDURE [web].[addTest] (
@error_num int OUTPUT,
@error_msg VARCHAR(MAX) OUTPUT
)
AS
BEGIN
SET @error_num = 99
SET @error_msg = 'Error! Oh my gosh!'
END
GO
PHP 的输出:
object(PDOStatement)#77 (1) {
["queryString"]=>
string(54) "EXEC [NGCustom].[web].[addTest] :error_num, :error_msg"
}
error_num: 0
error_msg:
AFAIK,FreeTDS 驱动程序不支持 OUTPUT 参数。我记得我的团队进行评估时的这一点。
这就是它不起作用的原因:http://www.freetds.org/faq.html#ms.output.parameters
编辑:这是来自 pyodbc 的参考(也运行在 FreeTDS 上),因此同样适用:https://code.google.com/p/pyodbc/wiki/StoredProcedures
引用:“结果:由于此时我们无法使用输出参数,因此您需要在结果集中返回结果。通常这意味着仅使用 SELECT 语句结束存储过程。”
您需要使用 SELECT 来代替。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)