资讯

精准传达 • 有效沟通

从品牌网站建设到网络营销策划,从策略到执行的一站式服务

PostgreSQL中VARIADIC函数如何使用

今天就跟大家聊聊有关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函数如何使用有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注创新互联行业资讯频道,感谢大家的支持。


网站名称:PostgreSQL中VARIADIC函数如何使用
网站路径:http://cdkjz.cn/article/pdshco.html
多年建站经验

多一份参考,总有益处

联系快上网,免费获得专属《策划方案》及报价

咨询相关问题或预约面谈,可以通过以下方式与我们联系

大客户专线   成都:13518219792   座机:028-86922220