本文我们学习PL/pgSQL结构块,包括如何写结构块和执行结构块。

什么是结构块

PL/pgSQL是结构块语言,因此,PL/pgSQL函数或过程是通过结构块进行组织。完整结构块的语法如下:

[ <<label>> ]
[ DECLARE
    declarations ]
BEGIN
    statements;
END [ label ];

详细说明如下:

  • 块有两部分组成:声明部分和主体部分。声明部分是可选的,而主体部分是必须的。块在end关键字后面使用分号(;)表示结束。
  • 块可以有个可选的标签在开始和结尾处。如果你想在块主体中使用exit语句或限定块中声明的变量名称时,需要使用块标签。
  • 主体部分是编写代码的地方,每条语句需要使用分号结束。

PL/pgSQL 块结构示例

下面示例描述一个简单块结构,一般称为匿名块:

DO $$ 
<<first_block>>
DECLARE
  counter integer := 0;
BEGIN 
   counter := counter + 1;
   RAISE NOTICE 'The current value of counter is %', counter;
END first_block $$;

运行结果:

NOTICE:  The current value of counter is 1

从pgAdmin中执行块,点击图示按钮:
padmin
注意DO语句不属于块结构。它用于执行匿名块。PostgreSQL 在9.0版本中引入DO语句。
在声明部分定义变量counter并设置为0.

在主体部分,是counter值加1,通过RAISE NOTICE语句输出其值。

first_block 标签仅为了演示需要,本例中没有啥意义。

** 什么是双 ($$) 符号?**

($$) 符号 是单引号(’)的替代符号。开发PL/pgSQL 时,无论是函数或过程,必须把主体部分放在一个字符串中。因此必须对主体部分的单引号进行转义表示:

'<<first_block>> DECLARE counter integer := 0; BEGIN counter := counter + 1; RAISE NOTICE ''The current value of counter is %'', counter; END first_block';

使用($$) 符号可以避免引号问题。也可以在$ procedure.

PL/pgSQL 子结构块

PL/pgSQL可以一个块在另一个块的主体中。一个块嵌入在另一个块中称为子块,包含子块的块称为外部块。
子块
子块用于组织语句,这样大块能被分为更小和更多逻辑子块。子块的变量的名称可以与外部块变量名称同名,虽然这在实践中不建议。当在子块中声明一个与外部变量同名的变量,外部变量在子块中被隐藏。如果需要访问外部块的变量,可以使用块标签作为变量的限定符,如下面示例:

DO $$ 
<<outer_block>>
DECLARE
  counter integer := 0;
BEGIN 
   counter := counter + 1;
   RAISE NOTICE 'The current value of counter is %', counter;
   DECLARE 
       counter integer := 0;
   BEGIN 
       counter := counter + 10;
       RAISE NOTICE 'The current value of counter in the subblock is %', counter;
       RAISE NOTICE 'The current value of counter in the outer block is %', outer_block.counter;
   RAISE NOTICE 'The current value of counter in the outer block is %', counter;

执行结果如下:

NOTICE:  The current value of counter is 1
NOTICE:  The current value of counter in the subblock is 10
NOTICE:  The current value of counter in the outer block is 1
NOTICE:  The current value of counter in the outer block is 1
  • 首先,在外部块中声明变量counter。
  • 接着在子块中也声明了一个同名变量。
  • 在进入子块之前,变量的值为1。在子块中,我们给变量counter值加10,然后打印出来。注意,这个改变仅影响子块中counter变量。
  • 然后,我们通过标签限定符引用外部变量:outer_block.counter
  • 最后,我们打印外部块变量,其值保持不变。

本文我们学习PL/pgSQL块结构,通过DO语句可以执行匿名块。

PostgreSql 的PL/pgSQL 块结构本文我们学习PL/pgSQL结构块,包括如何写结构块和执行结构块。什么是结构块PL/pgSQL是结构块语言,因此,PL/pgSQL函数或过程是通过结构块进行组织。完整结构块的语法如下:[ &lt;&lt;label&gt;&gt; ][ DECLARE declarations ]BEGIN statements; .....
只能采用从源码安装的方法,在执行./configure命令时指定较大的数据,一般也需要指定较大的WAL日志和WAL日志文件的大小。如果想指定128kb的数据、128kb的wal日志,64Mb的WAL日志文件大小,则configure命令如下 ./configure --prefix=/usr/local/pgsql0104/pgsql14.1 --with-perl --with-python --with-blocksize=128 --with-wal-blocksize=128 --wit
使用过Oracle的语句的都熟悉,在不用创建存储过程或函数就可以执行PLSQL数据库脚本,这样做通常可以用来做一些复杂业务数据初始化的功能。那么在PostgreSQL中也有相应的功能,称为PL/pgSQL,具体语法如下: [ <<label>> ] [ DECLARE declarations ] BEGIN statements END [ label ]; 语句由两部分组成:声明部分与主体部分,声明部分是可选的,主体部分是必须的,在主体部分最后的END使用
匿名代码介绍: 匿名代码是在PostgreSQL 9.X版本引入的新功能【注:9.0以下不支持,可通过select version()脚本确认自己使用的数据库版本】,通过DO关键字指定执行代码,其功能和函数类似,相当于轻量版的函数,但不能传参数和返回值。适合进行一些较为复杂的一次性查询,在日常中使用可以大大降低一些重复脚本的执行的人力成本。 准备工作——创建数据表: 在开始使用匿名代码之前,首先创建一张要操作的数据表作为函数中的操作对象。 create ta...
PostgreSQL 语句(也称为匿名代码)可以使用 `RETURN` 语句返回结果。在语句内部,你可以使用 PL/pgSQL 语言来编写逻辑。 以下是一个示例,演示如何在语句内部使用 `RETURN` 语句返回结果: ```SQL DO $$ DECLARE result INTEGER := 0; BEGIN result := 1 + 2; RETURN result; $$ LANGUAGE plpgsql; 在上面的代码中,我们定义了一个匿名代码,其中声明了一个名为 `result` 的整数变量。在代码的主体内部,我们将 `result` 的值设置为 1 加上 2,然后使用 `RETURN` 语句返回 `result` 的值。 要执行该代码并返回结果,可以使用 `SELECT` 语句来调用它: ```SQL SELECT * FROM (DO $$ ... $$ LANGUAGE plpgsql) subquery; 这将返回一个包含一个名为 `?column?` 的列的数据集,其中包含了我们在代码中返回的结果。 如果你想要在代码中返回更复杂的数据结构,例如表格或记录,可以使用 `RETURN QUERY` 语句返回查询结果集。例如: ```SQL DO $$ BEGIN RETURN QUERY SELECT id, name FROM users; $$ LANGUAGE plpgsql; 在上面的代码中,我们使用 `RETURN QUERY` 语句返回了一个查询结果集,该结果集包含了 `users` 表格中的 `id` 和 `name` 列。结果集将作为代码的返回值返回。