函数中的PostgreSQL CASE用法

时间:2012-01-19 09:56:49

标签: postgresql conditional case plpgsql

我们不能在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 ...

1 个答案:

答案 0 :(得分:18)

这涉及要conditional control structure CASEprocedural language PL/pgSQL使用的plpgsql functionsDO 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

根据文档,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是可选的,但如果关键字存在,则还必须给出表达式!