更新日期:2024年09月11日
正如内建的函数那样,您可通过在 SQL 和 SPL 语句中的表达式,使用 SPL 例程来执行
SPL 例程(以及来自 SPL 例程的外部例程)。表达式中使用的例程通常为函数,因为它
将值返回至语句的剩余部分。
例如,您可能通过将返回值分配给变量的 LET 语句来执行函数。下图中的语句执行相同
的任务。它们执行 SPL 例程内的外部函数,并将返回值分配给变量 a。
图: 执行 SPL 例程内的外部函数。
LET a = area( rectv.length, rectv.width );
CALL area( rectv.length, rectv.width ) RETURNING a;
-- 这些语句是等同的
GBase 8s SQL 指南:教程
南大通用数据技术股份有限公司 - 314 -
您还可从 SQL 语句执行 SPL 例程,
如下图所示。
假设您编写 SPL 函数 increase_by_pct,
对给定的价格增加给定的百分比。在您编写 SPL 例程之后,在任何其他 SPL 例程中都可
使用它。
图: 从 SQL 语句执行 SPL 例程。
CREATE FUNCTION raise_price ( num INT )
RETURNING DECIMAL;
DEFINE p DECIMAL;
SELECT increase_by_pct(price, 20) INTO p
FROM inventory WHERE prod_num = num;
RETURN p;
END FUNCTION;
该示例选择 inventory 的指定的行的 price 列,
并使用该值作为 SPL 函数 increase_by_pct 的
参数。然后,该函数返回新的 price 值,在变量中增加 20%。
操作场景
每个VC 在创建完distribution 后必须先执行initnodedatamap。
GBase 8a MPP Cluster 产品手册
3 集群安装升级与卸载
文档版本953(2022-04-10)
南大通用数据技术股份有限公司
81
操作步骤
使用数据库用户root 登录(root 用户默认密码是空),执行initnodedatamap 命令。
示例:分别在已创建vc1,vc2 在其上执行initnodedatamap。
$ gccli -uroot
GBase client 9.5.3.17.123187. Copyright (c) 2004-2020, GBase.
All Rights Reserved.
gbase> use vc vc1;
Query OK, 0 rows affected (Elapsed: 00:00:00.04)
gbase> initnodedatamap;
Query OK, 0 rows affected (Elapsed: 00:00:10.83)
gbase> use vc vc2;
Query OK, 0 rows affected (Elapsed: 00:00:00.00)
gbase> initnodedatamap;
Query OK, 0 rows affected (Elapsed: 00:00:15.78)