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

本文涉及的产品
云原生数据库 PolarDB MySQL 版,Serverless 5000PCU 100GB
简介:

本节书摘来自华章计算机《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数据库、数据库生态工具、云原生智能化数据库管控平台,为阿里巴巴经济体以及各个行业的企业客户和开发者提供从公共云到混合云再到私有云的完整解决方案,提供基于云基础设施进行数据从处理、到存储、再到计算与分析的一体化解决方案。本节课带你了解阿里云数据库产品家族及特性。
相关文章
|
1月前
|
存储 弹性计算 关系型数据库
阿里云服务器ESSD云盘性能等级PL0、PL1、PL2、PL3区别,云盘性能级别PL知识点参考
在我们选择阿里云服务器系统盘和数据盘时,如果是选择ESSD云盘,还需要选择云盘的云盘性能级别PL,PL性能级别有PL3、PL2、PL1、PL0四个性能级别的云盘规格,如果是通过阿里云的活动来购买云服务器的话,由于系统盘默认一般为20G或40G容量,可选的PL性能级别通常只有PL0(单盘IOPS性能上限1万)和PL1(单盘IOPS性能上限5万)可选择,有的用户肯能并不清楚ESSD云盘的性能等级之间有何区别,单盘IOPS性能指的是什么,本文为大家介绍一下ESSD云盘的云盘性能级别PL3、PL2、PL1、PL0相关知识点。
阿里云服务器ESSD云盘性能等级PL0、PL1、PL2、PL3区别,云盘性能级别PL知识点参考
|
4月前
|
前端开发 应用服务中间件 nginx
Next.js 创建项目到服务器部署(目录结构介绍、项目结构Demo、开发细节注意)
Next.js 创建项目到服务器部署(目录结构介绍、项目结构Demo、开发细节注意)
362 0
|
2月前
|
SQL 存储 缓存
PostgreSQL函数管理接口
学习PostgreSQL服务端开发必须要对函数管理接口有比较深入的了解
143 0
|
1月前
|
关系型数据库 PostgreSQL
postgresql日程排程函数的编写实例
postgresql日程排程函数的编写实例
|
2月前
|
SQL 关系型数据库 分布式数据库
在PolarDB for PostgreSQL中,你可以使用LIKE运算符来实现类似的查询功能,而不是使用IF函数
在PolarDB for PostgreSQL中,你可以使用LIKE运算符来实现类似的查询功能,而不是使用IF函数
43 7
|
2月前
|
存储 缓存 物联网
DP读书:鲲鹏处理器 架构与编程(二)服务器与处理器——高性能处理器的并行组织结构、ARM处理器
DP读书:鲲鹏处理器 架构与编程(二)服务器与处理器——高性能处理器的并行组织结构、ARM处理器
251 0
|
2月前
|
存储 算法 安全
【服务器数据恢复】HP EVA存储结构&原理&数据恢复方案
EVA是虚拟化存储,在工作过程中,EVA存储中的数据会不断地迁移,再加上运行在EVA上的应用都比较繁重,磁盘负载高,很容易出现故障。EVA是通过大量磁盘的冗余空间和故障后rss冗余磁盘动态迁移保护数据。但是如果磁盘掉线数量到达一个临界点,EVA存储就会崩溃。
【服务器数据恢复】HP EVA存储结构&原理&数据恢复方案
|
4月前
|
SQL 关系型数据库 C语言
PostgreSQL【应用 03】Docker部署的PostgreSQL扩展SQL之C语言函数(编写、编译、载入)计算向量余弦距离实例分享
PostgreSQL【应用 03】Docker部署的PostgreSQL扩展SQL之C语言函数(编写、编译、载入)计算向量余弦距离实例分享
45 0
|
4月前
|
SQL 关系型数据库 数据库
PostgreSQL【应用 02】扩展SQL之C语言函数(编写、编译、载入)实例分享
PostgreSQL【应用 02】扩展SQL之C语言函数(编写、编译、载入)实例分享
49 0
|
4月前
|
SQL 关系型数据库 PostgreSQL
PostgreSQL【SQL 01】根据条件更新字段值或追加信息STRPOS(string, substring)函数使用及LIKE函数对比
PostgreSQL【SQL 01】根据条件更新字段值或追加信息STRPOS(string, substring)函数使用及LIKE函数对比
54 0

热门文章

最新文章