Я пытаюсь использовать эту процедуру:
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 не существует.
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 ) );
без удачи ..
Спасибо за помощь!