返回首页

gbase数据、南大通用产品文档:GBase8sdectrunc() 函数

更新日期:2024年09月11日

dectrunc() 函数将四舍五入了的 decimal 类型数值截断到小数位。
语法

void dectrunc(d, s)
dec_t *d;
mint s;
d
指向 dectrunc() 截断其值的四舍五入了的数值的 decimal 结构的指针。
s
dectrunc() 将该值截断至的小数位的数目。对于此参数,请使用正数或零。

用法
下表展示以不同的输入,来自 dectrunc() 的样例输出。

截断之前的值
s 的值
截断了的值

正如内建的函数那样,您可通过在 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)