PostgreSQL CASE在函数中的用法
发布时间:2020-12-13 16:31:13  所属栏目:百科  来源:网络整理 
            导读:我们不能在SQL SELECT语句之外使用CASE条件? 例如.: CASE WHEN old.applies_to = 'admin' THEN _applies_to = 'My Self' ELSE _applies_to = initcap(old.applies_to)END _summary = _summary || 'liApply To: ' || _applies_to || '/li'; 我得到以下错误
                
                
                
            | 
                         
 我们不能在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关键字不是可选的.我引用上面的链接: 
 但是,您可以使用空的ELSE: CASE 
   WHEN old.applies_to = 'admin' THEN
      _applies_to := 'My Self';
   ELSE
      --  do nothing
END CASE; 
 这与ELSE是可选的SQL CASE表达式不同,但是如果存在关键字,则也必须给出表达式! (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!  | 
                  
