温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

PostgreSQL中VARIADIC函数如何使用

发布时间:2021-06-18 15:21:14 来源:亿速云 阅读:282 作者:Leah 栏目:大数据

今天就跟大家聊聊有关PostgreSQL中VARIADIC函数如何使用,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

1、示例

CREATE OR REPLACE FUNCTION test_v(p1 int, VARIADIC p2 any[])
RETURNS void AS
$test_v$
BEGIN
NULL;
END;
$test_v$
LANGUAGE plpgsql;

这里,VARIADIC参数必须是数组,而数组

2、使用

调用方式1

SELECT test_v(1,2,3);

调用方式2

SELECT test_v(1,VARIADIC '{2,3,4}'::int[]);

第一种方式其实在语义层会转换成第二种方式,这些逻辑在函数 ParseFuncOrColumn 中,有兴趣可以自行查看。

3、第二种调用方式的语法

  | func_name '(' VARIADIC func_arg_expr opt_sort_clause ')'
    {
      FuncCall *n = makeFuncCall($1, list_make1($4), @1);
      n->func_variadic = true;
      n->agg_order = $5;
      $$ = (Node *)n;
    }
  | func_name '(' func_arg_list ',' VARIADIC func_arg_expr opt_sort_clause ')'
    {
      FuncCall *n = makeFuncCall($1, lappend($3, $6), @1);
      n->func_variadic = true;
      n->agg_order = $7;
      $$ = (Node *)n;
    }

只是指定这是VARIADIC函数调用,参数并没有特别处理。

4、实际参数列表

在语法层,第一张调用方式有三个常量参数:整型 整型 整型,而第二种则是两个参数:整型 整型数组。第一种调用方式在上边说的 ParseFuncOrColumn 函数中,后两者合并为一个参数:数组表达式(ArrayExpr)。

5、不能多种参数类型混合

我们可以实现 func(int, int, int ...),但无法实现 func(int, text, int, text ...),数组不允许这么做,在语义层就会报错无法继续。

当然,这个限制并不会影响我们使用PG,并不会因为它函数就没法定义。主要的影响是迁移,比如Oracle应用会用到decode这样的函数,在现有机制下,并没有比较完美的方案去实现。

6、PL/pgSQL

文档中似乎没有提到PL/pgSQL对VARIADIC参数的支持(也许有,没仔细看),但它是可以处理的。而且从上边看,VARIADIC参数最后传递的是一个数组而已,不是什么特别的东西。

回归测试中的示例:

-- test variadic functions
create or replace function vari(variadic int[])
returns void as $$
begin
  for i in array_lower($1,1)..array_upper($1,1) loop
    raise notice '%', $1[i];
  end loop; end;
$$ language plpgsql;

看完上述内容,你们对PostgreSQL中VARIADIC函数如何使用有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注亿速云行业资讯频道,感谢大家的支持。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI