GaussDB-CALL

100 阅读2分钟

GaussDB-CALL

功能描述

使用CALL命令可以调用已定义的函数和存储过程。

注意事项

函数或存储过程的所有者、被授予了函数或存储过程EXECUTE权限的用户、或被授予EXECUTE ANY FUNCTION权限的用户,有权使用CALL命令,当三权分立开关关闭时,系统管理员默认拥有此权限。

语法格式

| ``` CALL [ schema. ] { func_name | procedure_name } ( param_expr );

| ------------------------------------------------------------------------ |

![](https://p9-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/b5602b91fa8a44b9972b6c507f1a9559~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAgamVycnl3YW5nMTk4Mw==:q75.awebp?rk3s=f64ab15b&x-expires=1772589147&x-signature=8btQgfao8Yx4IbMuYuy3ZHqvZ1M%3D)

#### 参数说明

-   **schema**

    函数或存储过程所在的模式名称。

-   **func_name**

    所调用函数或存储过程的名称。

    取值范围:已存在的函数名称。

    ![](https://p9-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/5051113ed8b34881a918093fe6d91ce5~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAgamVycnl3YW5nMTk4Mw==:q75.awebp?rk3s=f64ab15b&x-expires=1772589147&x-signature=qb4InwQbuctW90wzFk3Uztbondo%3D)

    支持使用DATABASE LINK方式对远端函数或存储过程进行操作,使用方式详情请见[DATABASE LINK](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/24.1.30/devg-dist/gaussdb-12-0711.html#ZH-CN_TOPIC_0000001865745520)。

-   **param_expr**

    参数列表可以用符号":="或者"=>"将参数名和参数值隔开,这种方法的好处是参数可以以任意顺序排列。若参数列表中仅出现参数值,则参数值的排列顺序必须和函数或存储过程定义时的相同。

    取值范围:已存在的函数参数名称或存储过程参数名称。

    ![](https://p9-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/4b90f358287c44708a5ab0f86ec9fb06~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAgamVycnl3YW5nMTk4Mw==:q75.awebp?rk3s=f64ab15b&x-expires=1772589147&x-signature=k730UhVKr8trT1MN6Yrt%2FJn4%2F6o%3D)

    -   参数可以包含入参(参数名和类型之间指定“IN”关键字)和出参(参数名和类型之间指定“OUT”关键字),使用CALL命令调用函数或存储过程时,对于非重载的函数,参数列表必须包含出参,出参可以传入一个变量或者任一常量,详见[示例](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/24.1.30/devg-dist/gaussdb-12-0523.html#ZH-CN_TOPIC_0000001911666569__zh-cn_topic_0000001704458673_zh-cn_topic_0059778236_s299dc001fa4b48cd9b56412a73db23c0)。

[]()[]()

#### 示例

| ```
--创建一个函数func_add_sql,计算两个整数的和,并返回结果。 gaussdb=# CREATE FUNCTION func_add_sql(num1 integer, num2 integer) RETURN integer AS BEGIN RETURN num1 + num2; END; /  --按参数值传递。 gaussdb=# CALL func_add_sql(1, 3);  --使用命名标记法传参。 gaussdb=# CALL func_add_sql(num1 => 1,num2 => 3); gaussdb=# CALL func_add_sql(num2 := 2, num1 := 3);  --删除函数。 gaussdb=# DROP FUNCTION func_add_sql;  --创建带出参的函数。 gaussdb=# CREATE FUNCTION func_increment_sql(num1 IN integer, num2 IN integer, res OUT integer) RETURN integer AS BEGIN res := num1 + num2; END; /  --出参传入常量。 gaussdb=# CALL func_increment_sql(1,2,1);  --出参传入变量。 gaussdb=# DECLARE res int; BEGIN func_increment_sql(1, 2, res); dbe_output.print_line(res); END; /  --删除函数。 gaussdb=# DROP FUNCTION func_increment_sql; 
``` |
| --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |

#### 相关链接

[CREATE FUNCTION](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/24.1.30/devg-dist/gaussdb-12-0546.html#ZH-CN_TOPIC_0000001911586717),[CREATE PROCEDURE](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/24.1.30/devg-dist/gaussdb-12-0558.html#ZH-CN_TOPIC_0000001911586749)

更多详情请参考GaussDB 文档中心:<https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/24.1.30/productdesc/qlh_03_0001.html>