我们不能在sql SELECT语句之外使用CASE条件?
例如.:
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... ^
任何帮助赞赏.
这关系到
procedural language PL/pgSQL的
conditional control structure
CASE
,将用于
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终止才能关闭它.
回答additional question in comment
根据文档,CASE语句的ELSE关键字不是可选的.我引用上面的链接:
If no match is found,the
ELSE
statements are executed;
but ifELSE
is not present,then aCASE_NOT_FOUND
exception is raised.
但是,您可以使用空的ELSE:
CASE WHEN old.applies_to = 'admin' THEN _applies_to := 'My Self'; ELSE -- do nothing END CASE;
这与ELSE是可选的sql CASE表达式不同,但是如果存在关键字,则也必须给出表达式!