我们不能在SQL CASE
语句之外使用SELECT
条件吗?
E.g:
CASE
WHEN old.applies_to = 'admin' THEN _applies_to = 'My Self'
ELSE _applies_to = initcap(old.applies_to)
END
_summary = _summary || '<li>Apply To: ' || _applies_to || '</li>';
我收到以下错误:
ERROR: syntax error at or near "_summary"
LINE 86: _summary = _summary || '<li>Apply To: ' || _applies ...
答案 0 :(得分:18)
这涉及要conditional control structure CASE
或procedural language PL/pgSQL使用的plpgsql functions的DO
statements。不要与CASE
expression of SQL混淆。不同的语言!而且语法规则也略有不同。
虽然SQL CASE
可以嵌入到PL / pgSQL代码中的SQL表达式中(这主要只是SQL命令的粘合剂),但是你不能拥有独立的SQL CASE
表达式(这是无意义的)
-- inside plpgsql code block:
CASE
WHEN old.applies_to = 'admin' THEN
_applies_to := 'My Self';
ELSE
_applies_to := initcap(old.applies_to);
END CASE;
您必须使用以分号(;
)和END CASE
结尾的完全限定语句才能将其关闭。
根据文档,ELSE
声明的CASE
关键字不是可选的。我引用上面的链接:
如果未找到匹配项,则执行
ELSE
语句; 但如果ELSE
不存在,则会引发CASE_NOT_FOUND
异常。
但是,您可以使用空的ELSE
:
CASE
WHEN old.applies_to = 'admin' THEN
_applies_to := 'My Self';
ELSE
-- do nothing
END CASE;
这与SQL CASE
表达式不同,其中ELSE
是可选的,但如果关键字存在,则还必须给出表达式!