我正在使用 sql server 2012 并连接到 php。当我在 sql management studio 中执行存储过程时,它工作正常。但是当我在 php 中调用存储过程时,它返回空值或 null 值
我找到了根本原因。我在该存储过程中使用 PRINT。如果我在存储过程中删除该打印,它在 php 中工作正常。如果我使用意味着它得到空值
为什么?以及如何在这种情况下从 PHP 中的存储过程获取结果?(sp 有打印语句)
存储过程:
CREATE PROCEDURE spname
@Id INT
AS
Begin
PRINT "some notes"
SELECT * FROM TABLE_NAME
end
PHP代码
$sp="EXEC spname @Id=20";
$query=$con->prepare($sp);
$query->execute();
$result = $query->fetchAll(PDO::FETCH_ASSOC);
print '<PRE>';
print_r($result);
最佳答案
请试试这个:
$sp="SET NOCOUNT ON;EXEC spname @Id=20";
$query=$con->prepare($sp);
$query->execute();
$result = $query->fetchAll(PDO::FETCH_ASSOC);
print '<PRE>';
print_r($result);
关于php - 存储过程在 php 中返回 null 或空值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28576384/