我正在使用这个 SP,在使用 mysql 工作台时得到了两个结果。
CREATE PROCEDURE SP(IN _start INT,IN _end INT,INOUT _count INT)
BEGIN
SET _count = (SELECT COUNT(*) FROM tbl);
SET @qry = CONCAT('select * from tbl limit ', _start, ',', _end);
PREPARE stmt FROM @qry;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;
END
但是与 PDO 一起使用时会返回此错误
$c=0;
$stmt = $this->_dbc->getConnection()->prepare("CALL SP(0,10,:count)");
$stmt->bindParam(":count",$c,PDO::PARAM_INT|PDO::PARAM_INPUT_OUTPUT,0);
$stmt->execute();
return $c;
PDOException' with message 'SQLSTATE[42000]: Syntax error or access violation: 1414 OUT or INOUT argument 3 for routine db22.SP is not a variable or NEW pseudo-variable in BEFORE trigger
但在改变
$this->_dbc->getConnection()->prepare("CALL SP(0,10,**:count**)");
至
$this->_dbc->getConnection()->prepare("CALL SP(0,10,@count)");
我没有返回任何错误,但总是将计数设为 0。
- :count 和 @count 有什么区别?
- 如何通过 pdo 获得准确的计数?