plpgsql系列教程(4.2)-函数返回常用数据类型——行数据类型

本文由 @小刘先森 原创,转载请注明出处。

PL/pgSQL系列文章,方便小伙伴们学习。

PL/pgSQL从入门到放弃(1)-入门
PL/pgSQL从入门到放弃(2)-变量定义与数据类型
PL/pgSQL从入门到放弃(3)-函数
PL/pgSQL从入门到放弃(4.1)-函数返回常用数据类型——组合数据类型
PL/pgSQL从入门到放弃(4.2)-函数返回常用数据类型——行数据类型
PL/pgSQL从入门到放弃(4.3)-函数返回常用数据类型——记录数据类型
PL/pgSQL从入门到放弃(4.4)-函数返回常用数据类型——复制数据类型
PL/pgSQL从入门到放弃(5)-条件语句与循环语句
PL/pgSQL从入门到放弃(6)-游标


返回基本数据类型,例如intvarcharjsonjsonb这些数据类型在函数返回以及使用的过程中没有什么特殊性,但是在写函数过程中会有返回行记录的需求,这几篇文章主要介绍如何返回rowtyperecord组合数据类型复制数据类型

行数据类型

在写函数时除了返回上篇文章写得组合数据类型外,还可以返回行数据类型,即返回某个表的一条行记录类型。如在GIS行业对某个数据进行抽稀时,则可以使用返回行数据类型,对某个表的数据进行处理后,返回同样数据格式。

一个组合类型的变量被称为一个行变量(或行类型变量)。这样一个变量可以保持一个SELECT或FOR查询结果的一整行,前提是查询的列集合匹配该变量被声明的类型。该行值的各个域可以使用通常的点号标记访问,例如rowvar.field。

通过使用table_name%ROWTYPE标记,一个行变量可以被声明为具有和一个现有表或视图的行相同的类型。它也可以通过给定一个组合类型名称来声明(因为每一个表都有一个相关联的具有相同名称的组合类型,所以在PostgreSQL中实际上写不写%ROWTYPE都没有关系。但是带有%ROWTYPE的形式可移植性更好)。

  • 函数示例(jcb_cddm 场地代码表)
  1. 声明函数时,使用 returns setof
  2. 返回时使用return next或者return query
-- return next
create or replace function jcb_cddm_filter(code varchar) returns SETOF jcb_cddm as $$
	declare
		r jcb_cddm%rowtype;
	begin
		for r in select * from jcb_cddm where substr(dm,5,1) = code loop
			return next r;
		end loop;
		return;
	end;
$$ language plpgsql;
-- return next
create or replace function jcb_cddm_filter(code varchar) returns SETOF jcb_cddm as $$
	declare
		r jcb_cddm%rowtype;
	begin
		return query select * from jcb_cddm where substr(dm,5,1) = code ;
		IF NOT FOUND THEN
        	RAISE EXCEPTION '未找到数据';
    	END IF;
		return;
	end;
$$ language plpgsql;
  • 函数运行
    行类型结果
    下一篇介绍返回记录数据类型(record)

关于作者

大家有需要介绍哪些部分,或者一些想法欢迎联系我。

GISer
QQ: 1016817543
邮箱:1016817543@qq.com
github:https://github.com/MrSmallLiu (欢迎star)

相关链接

以下为本人参与开发的一些库,欢迎各位Star、Issues、PR

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值