我正在尝试创建一个 MySQL 函数IS_IN_ENUM('value', 'val1', 'val2', 'val3')
,如果“value”在(“val1”、“val2”、“val3”)中,则该函数返回 true。我知道我可以做到SELECT 'value' IN ('val1', 'val2', 'val3')
,但这没那么有趣,因为我只想学习如何创建这样的函数。
我给你一个例子,考虑以下ADD
函数:
CREATE FUNCTION my_add (
a DOUBLE,
b DOUBLE
)
RETURNS DOUBLE
BEGIN
IF a IS NULL THEN
SET a = 0;
END IF;
IF b IS NULL THEN
SET b = 0;
END IF;
RETURN (a + b);
END;
如果我这样做SELECT my_add(1, 1)
,我会得到 2(哇!)。
如何改进此功能以便能够调用:
SELECT my_add(1, 1); -- 2
SELECT my_add(1, 1, 1); -- 3
SELECT my_add(1, 1, 1, 1); -- 4
SELECT my_add(1, 1, 1, 1, 1, 1, .....); -- n