Я пишу функцию, которая должна возвращать плавающее значение.
BEGIN
DECLARE due_amount DECIMAL(9,2);
SET due_amount = (SELECT due_amount FROM (
SELECT id, MAX(date), due_amount, user_id
FROM lunch_transaction
GROUP BY user_id
HAVING user_id = user) l);
IF due_amount IS NULL THEN
SET due_amount = 0.00;
END IF;
RETURN due_amount;
END
Функция возвращает значение 0.00
, даже если значение должно быть чем-то другим.
Выполнение только этого запроса:
(SELECT due_amount FROM (
SELECT id, MAX(date), due_amount, user_id
FROM lunch_transaction
GROUP BY user_id
HAVING user_id = user) l);
дает правильные выходные данные.
Как установить выходные данные запроса в переменную?