我正在调用一个简单的MySQL存储过程,该过程接收2个参数,但是当我尝试获取从PDO PHP返回的值时,由于var_dump而得到array(0){}。另外,我尝试了不同的方法来获取值,并且获得布尔值(始终为false)。 当我在数据库中测试存储过程时,它可以正常工作。
希望您能帮助我找到我的错误。 谢谢
MySQL存储过程:
CREATE DEFINER=`root`@`localhost` FUNCTION `F_esUsuarioValido`(`USUARIO_IN` VARCHAR(50),`CONTRASENA_IN` VARCHAR(50))
RETURNS tinyint(4)
LANGUAGE SQL
NOT DETERMINISTIC
CONTAINS SQL
SQL SECURITY DEFINER
BEGIN
DECLARE EXISTE INT;
SELECT STATUS
INTO EXISTE
FROM T_USUARIO
WHERE USUARIO = USUARIO_IN
AND CONTRASENA = CONTRASENA_IN;
IF EXISTE IS NULL THEN
RETURN 0;
ELSEIF EXISTE = 1 THEN
RETURN 1;
ELSEIF EXISTE = 0 THEN
RETURN 2;
END IF;
END
PHP代码:
public function esUsuarioValido($usuarioIN, $contrasenaIN) {
$con = new ConexionMySQL();
$pdo = $con->conectar();
$sql = 'CALL F_esUsuarioValido(?,?)';
$stmt = $pdo->prepare($sql);
$stmt->bindParam(1, $usuarioIN, PDO::PARAM_STR);
$stmt->bindParam(2, $contrasenaIN, PDO::PARAM_STR);
$stmt->execute();
$result = $stmt->fetchAll(PDO::FETCH_ASSOC);
var_dump($result);
}
我得到的结果是: 数组(0){} 或bool(false)当我尝试检索时: $ result = $ stmt-> fetch(); var_dump($ result);
答案 0 :(得分:0)
我已经解决了。 我没有在MySQL中创建具有默认返回值的函数,而是将其创建为具有2个参数IN和1个参数OUT的存储过程,并根据我的条件在过程内将值分配给该OUT参数,而没有return语句。
CREATE DEFINER=`root`@`localhost` PROCEDURE `F_esUsuarioValido`(
IN `USUARIO_IN` VARCHAR(50),
IN `CONTRASENA_IN` VARCHAR(50),
OUT `ES_VALIDO_OUT` TINYINT
)
LANGUAGE SQL
NOT DETERMINISTIC
CONTAINS SQL
SQL SECURITY DEFINER
BEGIN
DECLARE EXISTE INT;
SELECT STATUS
INTO EXISTE
FROM T_USUARIO
WHERE USUARIO = USUARIO_IN
AND CONTRASENA = CONTRASENA_IN;
IF EXISTE IS NULL THEN
SET ES_VALIDO_OUT = 0;
ELSEIF EXISTE = 1 THEN
SET ES_VALIDO_OUT = 1;
ELSEIF EXISTE = 0 THEN
SET ES_VALIDO_OUT = 2;
END IF;
END
然后在PHP PDO中,我修改了语句,使其具有2IN和1个OUT参数,使用PDO :: bindParam仅设置IN参数,并且要检索OUT参数,必须查询SELECT @OUTParam:
public function esUsuarioValido($usuarioIN, $contrasenaIN) {
$con = new ConexionMySQL();
$pdo = $con->conectar();
$sql = 'CALL F_esUsuarioValido(:usuario, :contrasena, @esValido)';
$stmt = $pdo->prepare($sql);
$stmt->bindParam(":usuario", $usuarioIN, PDO::PARAM_STR);
$stmt->bindParam(":contrasena", $contrasenaIN, PDO::PARAM_STR);
$stmt->execute();
$stmt->closeCursor();
$row = $pdo->query("SELECT @esValido AS esValido")->fetch(PDO::FETCH_ASSOC);
var_dump($row);
}
然后,var_dump($ row)显示变量esValido具有正确的值。
这个网站对我有很多帮助:http://www.mysqltutorial.org/php-calling-mysql-stored-procedures/
要了解函数和存储过程返回值之间的区别,该网站提供了帮助:https://www.quora.com/What-difference-between-stored-procedures-and-functions-in-MySQL
希望这个答案可以对其他许多人有所帮助。 问候!