《PostgreSQL服务器编程》一一3.2 PL/pgSQL函数的结构

简介:
+关注继续查看

本节书摘来自华章计算机《PostgreSQL服务器编程》一书中的第3章,第3.2节,作者:(美)Hannu Krosing, Jim Mlodgenski, Kirk Roybal 著
,更多章节内容可以访问云栖社区“华章计算机”公众号查看。

3.2 PL/pgSQL函数的结构

如果我们想运行一个PL/pgSQL函数,实际上并不需要太多元素。以下就是一个非常简单的例子:

image

前面这个函数显示了最少元素的PL / pgSQL函数。该函数为substring内置函数创建了一个别名mid。对于Microsoft SQL Server或者MySQL的开发者而言,这是一个非常合适的别名,并且他们可以弄明白mid函数的实现过程。同时,这个函数也阐述了最基础的参数传递策略。这些参数在函数中并未被命名而是通过从左至右的相对位置被访问的。
PL / pgSQL函数的基本元素由名称、参数、返回类型、主体和语言组成。这里可能会有争议,有人会认为参数与返回值都并不是函数的必要元素。对于不需要响应的数据处理程序而言,这可能是对的,但如果需要返回一个TRUE值来告知程序已成功,此时就需要谨慎处理了。
访问函数参数
除了通过序数顺序,函数参数也可以通过名字进行传递和访问。如果通过名字访问参数,这样会增加函数代码的可读性。以下是一个使用命名参数的函数范例:
image

前面这个函数同时展示了mid函数的重载(over loading)。重载是PostgreSQL函数的另一个特性,它可以允许多个程序使用相同的名称,但使用不同的参数。在这种情况下,我们首先声明了这个mid函数具有3个参数。在这个例子中,重载是被用来执行mid函数的替代形式,这里只有2个参数。当省略第3个参数时,结果就是字符串,该字符串从starting_point开始,持续到输入字符串的结尾。
image

以上代码会产生如下结果:
image

为了能够通过名字访问函数参数,PostgreSQL会基于语句做一些理性猜测。让我们对着以下函数思考片刻:
image
image

这是一个非常暴力的编程案例,基本会被收录在如何不编写函数例子中。然而,PostgreSQL是非常智能的,它能正确地推断出:function参数的内容仅在VALUES列表中才有效。“参数”的其他所有事件实际上均是PostgreSQL的物理实体。
同时,我们也介绍了函数的一个可选部分。在BEGIN语句之前,我们声明一个变量。在这部分出现的变量在函数执行过程是有效的。
在这个函数中,同样值得注意的是语句RETURNING id INTO retval。这个特性能够让开发者指定记录的标识字段,并在插入记录后,返回那个字段值。之后,我们的函数将这个值返回给调用者,告知函数已执行成功并提供查找方法,以查询之前被插入的记录。

相关实践学习
使用PolarDB和ECS搭建门户网站
本场景主要介绍基于PolarDB和ECS实现搭建门户网站。
阿里云数据库产品家族及特性
阿里云智能数据库产品团队一直致力于不断健全产品体系,提升产品性能,打磨产品功能,从而帮助客户实现更加极致的弹性能力、具备更强的扩展能力、并利用云设施进一步降低企业成本。以云原生+分布式为核心技术抓手,打造以自研的在线事务型(OLTP)数据库Polar DB和在线分析型(OLAP)数据库Analytic DB为代表的新一代企业级云原生数据库产品体系, 结合NoSQL数据库、数据库生态工具、云原生智能化数据库管控平台,为阿里巴巴经济体以及各个行业的企业客户和开发者提供从公共云到混合云再到私有云的完整解决方案,提供基于云基础设施进行数据从处理、到存储、再到计算与分析的一体化解决方案。本节课带你了解阿里云数据库产品家族及特性。
相关文章
|
关系型数据库 PostgreSQL
『PostgreSQL』PGSQL手动创建Sequence序列
📣读完这篇文章里你能收获到 - 在PostgreSQL中对Sequence的管理及使用
379 0
『PostgreSQL』PGSQL手动创建Sequence序列
|
关系型数据库 数据库 PostgreSQL
PgSQL · 特性分析 · 浅析PostgreSQL 中的JIT
--- title: PgSQL · 特性分析 · 浅析PostgreSQL 中的JIT author: 卓刀 --- ## 背景 估计很多同学看过之前的月报[PgSQL · 特性分析· JIT 在数据仓库中的应用价值](http://mysql.taobao.org/monthly/2016/11/10/),对JIT(just in time)和LLVM(Low Level Vir
2534 0
|
关系型数据库 PHP 数据库
CentOS6.9编译安装postgresql和php的pdo_pgsql,pgsql扩展
这篇笔记记录了在CentOS6.9中源码编译安装postgresql的过程,也记录了源码编译安装php的pdo_pgsql,pgsql扩展的过程,由于mysql存在闭源风险,现在postgresql真是越来越火啊
1954 0
|
关系型数据库 PostgreSQL 索引
PgSQL · 应用案例 · PostgreSQL 图像搜索实践
背景 imgsmlr是PostgreSQL的一款支持以图搜图的插件, 支持 1、几种图像特征值数据类型, 2、图像特征值相似算子, 3、图像特征值相似排序索引支持, 4、图像相似排序的索引(通过扩展GiST索引接口实现)支持, 5、png,gif等图像格式特征值提取函数。
1820 0
|
SQL 关系型数据库 Java
PgSQL · 应用案例 · PostgreSQL flashback(闪回) 功能实现与介绍
背景 闪回的需求往往是救命的需求,因为通常情况下数据库正常运行是不需要闪回的,往往是出现了误操作,被攻击,被注入后,数据库的数据被删除或恶意纂改并且纂改的事务已提交,也就是说纂改已经被持久化了。 这种情况下需要闪回来救命,回到被破坏前的状态。
2965 0
|
SQL 关系型数据库 测试技术
PgSQL · 应用案例 · 阿里云 RDS PostgreSQL 高并发特性 vs 社区版本
背景 进程模型数据库,需要为每个会话指派独立的进程与之服务,在连接数非常多,且大都是活跃连接时,进程调度浪费或引入的开销甚至远远大于实际任务需要的开销(例如上下文切换,MEMCPY等),性能下降会较为严重。
2763 0
热门文章
最新文章
推荐文章
更多