Mysql: Вызов хранимой процедуры внутри процедуры с возвращаемым значением

#mysql #stored-procedures

#mysql #хранимые процедуры

Вопрос:

Я пытаюсь использовать эту процедуру:

 DELIMITER $$

CREATE DEFINER=`root`@`localhost` PROCEDURE `sp_login`(
    IN in_Email VARCHAR(60),
    IN in_Pass VARCHAR(45)
    )
BEGIN
    DECLARE d_UserType VARCHAR(45);
    SET d_UserType := db.get_usertype( (SELECT ID FROM User WHERE Email = in_Email ) );

    IF (d_UserType = '1') THEN

        SELECT * FROM User inner join tableA on tableA.ID = User.tableA_ID;

    ELSEIF (d_UserType = '2') THEN

        SELECT * FROM User inner join tableB on tableB.ID = User.tableB_ID;

    ELSEIF (d_UserType = '3') THEN

        SELECT * FROM User inner join tableC on tableC.ID = User.tableC_ID;

    END IF;
END
  

Но я получаю следующую ошибку: ОШИБКА 1305 (42000): ФУНКЦИЯ db.get_usertype не существует.

The

 CALL db.get_usertype( (SELECT ID FROM User WHERE Email = 'example@example.com') );           
  

работает нормально, когда я тестирую ее в одиночку. Кто-нибудь знает, почему это не работает?

Я пытался:

 SET d_UserType := CALL db.get_usertype( (SELECT ID FROM User WHERE Email = in_Email ) );
SET d_UserType := EXEC db.get_usertype( (SELECT ID FROM User WHERE Email = in_Email ) );
SET d_UserType := EXECUTE db.get_usertype( (SELECT ID FROM User WHERE Email = in_Email ) );
  

безуспешно..

Спасибо за всю помощь!

Ответ №1:

Редактировать Полностью игнорируйте мой предыдущий комментарий о вызове хранимых процедур в хранимых процедурах! Хранимая процедура не возвращает результат. Однако вы можете вставить хранимую процедуру во временную таблицу, из которой вы можете выбирать. Следующий ответ по-прежнему является тем, что вы ищете.

 CALL db.get_usertype((SELECT ID FROM User WHERE Email = in_Email ));
SET d_UserType = (SELECT usertype FROM temp_get_usertype);
  

Я полагаю, что вместо этого вы хотите превратить get_usertype в функцию. В некоторых случаях вместо этого можно использовать представление.

 SET d_UserType = db.get_usertype((SELECT ID FROM User WHERE Email = in_Email ))
  

например

 CREATE FUNCTION `get_usertype`(userID INT) RETURNS INT
BEGIN
    DECLARE $type INT;
    ...
    RETURN $type;
END