温馨提示×

温馨提示×

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

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

PostgreSQL函数如何返回OUT参数

发布时间:2021-07-09 18:04:09 来源:亿速云 阅读:876 作者:chen 栏目:大数据

本篇内容主要讲解“PostgreSQL函数如何返回OUT参数”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“PostgreSQL函数如何返回OUT参数”吧!

1、系统表 pg_proc 的字段含义

prorettype :返回值类型
proretset:返回值是否为集合
proargmodes:参数模式(IN、OUT、INOUT)

2、查找现成的示例

一般我们都能在PG的现有代码中找到使用方法:

SELECT proname,proargmodes,prorettype::regtype,array_position(proargmodes, 'o') FROM pg_proc
  WHERE NOT proretset AND proargmodes IS NOT NULL
    AND (array_position(proargmodes, 'o') IS NOT NULL
      OR array_position(proargmodes, 'b') IS NOT NULL)
  LIMIT 10;

返回包含OUT和INOUT参数的函数定义,'b' 为 INOUT参数。注意上边 ::regtype 的用法,增强结果的可读性:

pg_stat_get_archiver               | {o,o,o,o,o,o,o} | record | 1
pg_event_trigger_table_rewrite_oid | {o}             | oid    | 1

更多结果略。

3、多个OUT参数的返回

打开函数 pg_stat_get_archiver

// 自己定义TupleDesc,数量不包含IN入参
// 与前边讲过的返回结果集构建方法相同
tupdesc = CreateTemplateTupleDesc(7);
// 不一样的地方
BlessTupleDesc(tupdesc);

/* 构建 values 和 nulls 数组 */

// 返回结果
PG_RETURN_DATUM(HeapTupleGetDatum(heap_form_tuple(tupdesc, values, nulls)));

结果集函数在 TupleDescGetAttInMetadata 中调用 BlessTupleDesc

4、返回单个出参

直接调用 PG_RETURN_xxx 系列返回即可,pg_event_trigger_table_rewrite_oid 函数中:

PG_RETURN_OID(currentEventTriggerState->table_rewrite_oid);

5、INOUT参数

官方代码没有例子,猜测可以这样:输入值用 PG_GETARG_xx 取得,输出与OUT相同,有兴趣可以写个代码自己试试。

到此,相信大家对“PostgreSQL函数如何返回OUT参数”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

向AI问一下细节

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

AI