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,结果是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 │ │
│ └───────┘ │
└───────────┘