Postgresql自定义函数

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)

 

 

你可能感兴趣的:(数据库)