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
命令。例如,如果我们声明了两个整型变量x
和y
,并且我们写
<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
,但它不能包含顶级UNION
、INTERSECT
或EXCEPT
子句。例如,可以使用以下命令来测试表是否非空
<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。)IF
THEN
SELECT count(*) > 0 FROM my_table
SELECT