版权声明:转载请留言告知,注明出处 https://blog.csdn.net/qq_36213352/article/details/86698682
PostgreSQL函数也称为PostgreSQL存储过程。 PostgreSQL函数或存储过程是存储在数据库服务器上并可以使用SQL界面调用的一组SQL和过程语句(声明,分配,循环,控制流程等)。
语法:
CREATE [OR REPLACE] FUNCTION function_name (arguments)
RETURNS return_datatype AS $variable_name$
DECLARE
declaration;
[...]
BEGIN
< function_body >
[...]
RETURN { variable_name | value }
END; LANGUAGE plpgsql;
参数说明
function_name:指定函数的名称。
[OR REPLACE]:是可选的,它允许修改/替换现有函数。
DECLARE:定义参数(参数名写在前面 类型写在后面)。
BEGIN~END: 在中间写方法主体。
RETURN:指定要从函数返回的数据类型(它可以是基础,复合或域类型,或者也可以引用表列的类型)。
LANGUAGE:它指定实现该函数的语言的名称。
下面我将创建一个简单的函数:
CREATE OR REPLACE FUNCTION test(id uuid)
RETURNS INTEGER
LANGUAGE plpgsql
AS
$$
declare
count integer;
begin
count = (SELECT
json_array_length(A.json::json -> 'features')
FROM "Json" A
WHERE A.uid = id);
return count;
end;
$$
该函数的功能是用来返回json中数组的长度的
定义好该函数后,我们可以像调用其他的函数一样调用它
SELECT test(id)
返回数组长度(integer)