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

本文涉及的产品
云原生数据库 PolarDB MySQL 版,通用型 2核8GB 50GB
云原生数据库 PolarDB PostgreSQL 版,标准版 2核4GB 50GB
简介:

本节书摘来自华章计算机《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数据库、数据库生态工具、云原生智能化数据库管控平台,为阿里巴巴经济体以及各个行业的企业客户和开发者提供从公共云到混合云再到私有云的完整解决方案,提供基于云基础设施进行数据从处理、到存储、再到计算与分析的一体化解决方案。本节课带你了解阿里云数据库产品家族及特性。
相关文章
|
12月前
|
存储 关系型数据库 数据库
【赵渝强老师】PostgreSQL的逻辑存储结构
PostgreSQL的逻辑存储结构包括数据库集群、数据库、表空间、段、区、块等。每个对象都有唯一的对象标识符OID,并存储于相应的系统目录表中。集群由单个服务器实例管理,包含多个数据库、用户及对象。表空间是数据库的逻辑存储单元,用于组织逻辑相关的数据结构。段是分配给表、索引等逻辑结构的空间集合,区是段的基本组成单位,而块则是最小的逻辑存储单位。
248 2
【赵渝强老师】PostgreSQL的逻辑存储结构
|
关系型数据库 Serverless 定位技术
PostgreSQL GIS函数判断两条线有交点的函数是什么?
PostgreSQL GIS函数判断两条线有交点的函数是什么?
856 60
|
11月前
|
存储 SQL 关系型数据库
【赵渝强老师】PostgreSQL的物理存储结构
PostgreSQL在初始化时通过环境变量$PGDATA指定的目录下生成各类文件,构成其物理存储结构,包括数据文件、日志文件(如运行日志、WAL预写日志、事务日志和服务器日志)、控制文件及参数文件等,确保数据库的高效运行与数据安全。
269 1
|
SQL 自然语言处理 关系型数据库
在 PostgreSQL 中使用 `REPLACE` 函数
【8月更文挑战第8天】
1980 9
在 PostgreSQL 中使用 `REPLACE` 函数
|
运维 监控 关系型数据库
【一文搞懂PGSQL】7. PostgreSQL + repmgr + witness 高可用架构
该文档介绍了如何构建基于PostgreSQL的高可用架构,利用repmgr进行集群管理和故障转移,并引入witness节点增强网络故障检测能力。repmgr是一款轻量级的开源工具,支持一键部署、自动故障转移及分布式节点管理。文档详细描述了环境搭建步骤,包括配置postgresql参数、安装与配置repmgr、注册集群节点以及配置witness节点等。此外,还提供了故障手动与自动切换的方法及常用命令,确保集群稳定运行。
|
SQL 关系型数据库 C语言
PostgreSQL SQL扩展 ---- C语言函数(三)
可以用C(或者与C兼容,比如C++)语言编写用户自定义函数(User-defined functions)。这些函数被编译到动态可加载目标文件(也称为共享库)中并被守护进程加载到服务中。“C语言函数”与“内部函数”的区别就在于动态加载这个特性,二者的实际编码约定本质上是相同的(因此,标准的内部函数库为用户自定义C语言函数提供了丰富的示例代码)
|
关系型数据库 PostgreSQL
PostgreSQL的null值函数
【8月更文挑战第20天】PostgreSQL的null值函数
462 3
|
SQL Oracle 关系型数据库
|
关系型数据库 BI 数据处理
|
SQL 关系型数据库 MySQL
SQL Server、MySQL、PostgreSQL:主流数据库SQL语法异同比较——深入探讨数据类型、分页查询、表创建与数据插入、函数和索引等关键语法差异,为跨数据库开发提供实用指导
【8月更文挑战第31天】SQL Server、MySQL和PostgreSQL是当今最流行的关系型数据库管理系统,均使用SQL作为查询语言,但在语法和功能实现上存在差异。本文将比较它们在数据类型、分页查询、创建和插入数据以及函数和索引等方面的异同,帮助开发者更好地理解和使用这些数据库。尽管它们共用SQL语言,但每个系统都有独特的语法规则,了解这些差异有助于提升开发效率和项目成功率。
1477 0

推荐镜像

更多
下一篇
开通oss服务