我有一个存储过程IsUserPresent喜欢:PHP的mysqli准备语句存储过程输出参数
DELIMITER $$
CREATE PROCEDURE IsUserPresent(
in userid varchar (150),
out isPresent bit
)
BEGIN
SET isPresent=0;
SELECT COUNT(*)
INTO isPresent
FROM users_table
WHERE users_table.userid=userid;
END$$
,我想使用的mysqli准备好的声明从PHP调用它。我正在做下面的代码片段,但它给了我警告。
$connect=&ConnectDB();
$stmt=$connect->prepare("CALL IsUserPresent(?,?)");
$stmt->bind_param('si',$uid,$userCount);
$stmt->execute();
$toRet = $userCount!=0;
Disconnect($connect);
return $toRet;
警告如下:
Premature end of data (mysqlnd_wireprotocol.c:1112)
Warning: mysqli_stmt::execute(): RSET_HEADER packet 1 bytes shorter than expected
Warning: mysqli_stmt::execute(): Error reading result set's header
上述声明放入p_isPresent中是什么?我不认为我们可以使用外部嵌套查询返回的结果。谢谢你的提示。 – Talha5389 2014-09-05 13:41:35
'exists()'返回0或1(true或false)。当你将结果放入一个变量时,子查询不是问题。 – fancyPants 2014-09-05 14:51:35