PostgreSQL CASE在函数中的用法

我们不能在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/pgSQLconditional control structure CASE,将用于 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

根据文档,CASE语句的ELSE关键字不是可选的.我引用上面的链接:

If no match is found,the ELSE statements are executed;
but if ELSE is not present,then a CASE_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表达式不同,但是如果存在关键字,则也必须给出表达式!

相关文章

文章浏览阅读601次。Oracle的数据导入导出是一项基本的技能,...
文章浏览阅读553次。开头还是介绍一下群,如果感兴趣polardb...
文章浏览阅读3.5k次,点赞3次,收藏7次。折腾了两个小时多才...
文章浏览阅读2.7k次。JSON 代表 JavaScript Object Notation...
文章浏览阅读2.9k次,点赞2次,收藏6次。navicat 连接postgr...
文章浏览阅读1.4k次。postgre进阶sql,包含分组排序、JSON解...