#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