EXECUTE IMMEDIATE
引入或更新于:v1.2.452
执行 SQL 脚本。有关如何为 Databend 编写 SQL 脚本,请参阅存储过程与 SQL 脚本。
语法
EXECUTE IMMEDIATE $$
BEGIN
<procedure_body>
RETURN <return_value>; -- 用于返回单个值
-- 或
RETURN TABLE(<select_query>); -- 用于返回表
END;
$$;
示例
此示例使用循环从 -1 到 2 进行迭代,将 sum 递增,最终结果为总和(2):
EXECUTE IMMEDIATE $$
BEGIN
LET x := -1;
LET sum := 0;
FOR x IN x TO x + 3 DO
sum := sum + x;
END FOR;
RETURN sum;
END;
$$;
┌────────┐
│ Result │
│ String │
├────────┤
│ 2 │
└────────┘
以下示例返回一个包含列 1 + 1 和值 2 的表:
EXECUTE IMMEDIATE $$
BEGIN
LET x := 1;
RETURN TABLE(SELECT :x + 1);
END;
$$;
┌───────────┐
│ Result │
│ String │
├───────────┤
│ ┌───────┐ │
│ │ 1 + 1 │ │
│ │ UInt8 │ │
│ ├───────┤ │
│ │ 2 │ │
│ └───────┘ │
└───────────┘

