1

我正在尝试在 Postgres 8.2 中编写一个函数,它将分析我们用于报告目的的数据集中的 4 个特定列,然后返回用特定文本对记录进行分类的文本。

在我们旧的报告环境中,我会利用报告工具(Crystal Reports)来计算这个,但我收到的指令是它应该作为数据库中的一个函数来完成。

这是我正在尝试做的一个示例(请原谅错误,我仍在学习基础知识)

CREATE FUNCTION fnc_Breakdown(character varying, character varying, character varying, character varying)  
RETURNS character varying AS $$
DECLARE
breakdown character varying; 
BEGIN
IF $1 in ('ABCD') THEN breakdown:= "CSS"
ELSE
IF $1 like ('DCA%) AND $2 IN ('District 123','District 124') and $3 IN ('
THEN breakdown:= "FAB"
ELSE breakdown:= "OTHERS"
END IF;
RETURN breakdown;
END;

$$ LANGUAGE plpgsql IMMUTABLE;
4

1 回答 1

0

您的函数需要一些格式和分号,但总的来说没问题。我还建议一些友好的格式,记住你是为人而不是为计算机编写代码:

create or replace function fnc_Breakdown
(
  character varying,
  character varying,
  character varying,
  character varying
)
returns character varying as $$
declare
  breakdown character varying; 
begin
  if $1 = 'ABCD' then
    breakdown := 'CSS';
  elseif $1 like 'DCA%' and $2 in ('District 123','District 124') then
    breakdown:= 'FAB';
  else
    breakdown:= 'OTHERS';
  end if;
  return breakdown;
end;
$$ language plpgsql immutable;

实际上,这样一个简单的任务完全可以不用函数来完成,只需使用 case 表达式:

case
    when a = 'ABCD' then
        'CSS'
    when a like 'DCA%' and b in ('District 123','District 124') then
        'FAB'
    else
        'OTHERS'
end

看看sql fiddle demo摆弄查询

于 2013-08-27T16:06:03.523 回答