今天就跟大家聊聊有关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函数如何使用有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注亿速云行业资讯频道,感谢大家的支持。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。