第 41 章 PL/pgSQL — SQL过程语言 41.4。表达式

41.4。表达式

PL/pgSQL语句中使用的所有表达式都使用服务器的主SQL执行器进行处理。例如,当您编写如下PL/pgSQL语句时

<span style="color:#000000"><span style="background-color:var(--doccontent-pre-code-bg-color)">如果<em><code>expression</code></em>那么...
</span></span>

PL/pgSQL将通过提供如下查询来评估表达式

<span style="color:#000000"><span style="background-color:var(--doccontent-pre-code-bg-color)">选择<em><code>expression</code></em>
</span></span>

到主 SQL 引擎。在形成SELECT命令时,任何出现的PL/pgSQL变量名称都会被查询参数替换,如第 41.11.1 节中详细讨论的。这使得查询计划只需SELECT准备一次,然后即可重复用于具有不同变量值的后续评估。因此,第一次使用表达式时真正发生的事情本质上是一个PREPARE命令。例如,如果我们声明了两个整型变量xy,并且我们写

<span style="color:#000000"><span style="background-color:var(--doccontent-pre-code-bg-color)">如果 x < y 那么...
</span></span>

幕后发生的事情相当于

<span style="color:#000000"><span style="background-color:var(--doccontent-pre-code-bg-color)">PREPARE <em><code>statement_name</code></em>(整数, 整数) AS SELECT $1 < $2;
</span></span>

然后,EXECUTE每次执行该语句时都会生成该准备好的语句,并将PL/pgSQLIF变量的当前值作为参数值提供。通常这些细节对于PL/pgSQL用户来说并不重要,但是在尝试诊断问题时了解它们很有用。更多信息见第 41.11.2 节

由于 anexpression被转换为SELECT命令,因此它可以包含与普通子句相同的子句SELECT,但它不能包含顶级UNIONINTERSECTEXCEPT子句。例如,可以使用以下命令来测试表是否非空

<span style="color:#000000"><span style="background-color:var(--doccontent-pre-code-bg-color)">IF count(*) > 0 FROM my_table THEN ...
</span></span>

因为andexpression之间的内容被解析为好像是。必须生成一列,并且不能多于一行。 (如果它没有产生任何行,则结果被视为 NULL。)IFTHENSELECT count(*) > 0 FROM my_tableSELECT

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值