在自定义聚合函数中查找 SUM 和 MAX

问题描述 投票:0回答:1

我最近一直在使用自定义聚合函数。 在此自定义聚合中,第一个函数无法正确计算总和和最大值。 我使用复合类型返回总和和最大值。

我尝试过用数组附加所有内容,但这不是一种有效的工作方式

CREATE TYPE sum_max_complex AS (sum real, max_v real);

CREATE OR REPLACE FUNCTION calculateSum(sum_max_complex, real) RETURNS sum_max_complex AS $$
DECLARE 
   sumValue real := 0;
   max_v real := $2;
   output sum_max_complex;
BEGIN
    RAISE NOTICE '-------------------';
    RAISE NOTICE 'IL PRIMO VALORE DI INPUT E: % ... %',$1.sum,$1.max_v;
    RAISE NOTICE 'IL SECONDO VALORE DI INPUT E: %',$2;
    IF $2 IS NOT NULL THEN
      sumValue := calculateSumAggregate(sumValue,$2) + sumValue;
    ELSE
      sumValue := sumValue;
    END IF;
    max_v := searchmaximumvalue(max_v,$2);


    output.sum := sumValue;
    output.max_v := max_v;

    RAISE NOTICE '-------------------';
    RAISE NOTICE 'IL VALORE DI OUTPUT SONO: % ... %',output.sum,output.max_v;
    RETURN output;
END;
$$ LANGUAGE plpgsql;

CREATE OR REPLACE FUNCTION addLaplacianNoiseSum(sum_max_complex) RETURNS real AS $$
DECLARE
   epsilon real := 0.005;
   sensivity real := $1.max_v;
   laplaceDistribution real;
BEGIN

   laplaceDistribution := generaterandomvalues(sensivity / (epsilon));

   RETURN  $1.sum + laplaceDistribution;
END;
$$ LANGUAGE plpgsql;

CREATE AGGREGATE SUM_LAPLACE(real)
(
  SFUNC = calculateSum,
  STYPE = sum_max_complex,
  FINALFUNC = addLaplacianNoiseSum
);

在我的表列中,我的值为:19,22,22.5,27。 它在第一个函数中的 $2 参数方法中采用正确的值,但不会累加和求和每个值。

sql postgresql plpgsql
1个回答
2
投票

您似乎从未添加过 sum_max_complex 类型中存储的值。 这是一个简化的示例,大致显示了您应该做什么。 我不知道calculateSumAggregate或generaterandomvalues做什么,所以我无法重现这些。

CREATE TYPE sum_max_complex AS (sum real, max_v real);

CREATE OR REPLACE FUNCTION calculateSum(sum_max_complex, real) RETURNS sum_max_complex AS $$
select ROW(
    $1.sum + coalesce($2, 0),
    greatest($1.max_v, $2)
)::sum_max_complex;
$$ LANGUAGE SQL IMMUTABLE;

CREATE OR REPLACE FUNCTION addLaplacianNoiseSum(sum_max_complex) RETURNS real AS $$
  select $1.sum + ($1.max_v/0.005);
$$ LANGUAGE SQL IMMUTABLE;

CREATE AGGREGATE SUM_LAPLACE(real)
(
  SFUNC = calculateSum,
  STYPE = sum_max_complex,
  FINALFUNC = addLaplacianNoiseSum,
  INITCOND = '(0, 0)'
);

with a as (select a from (values (19), (22), (22.5), (27)) v(a))
select sum_laplace(a) from a;
 sum_laplace
-------------
      5490.5
© www.soinside.com 2019 - 2024. All rights reserved.