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

Find SUM and MAX in custom aggregate function

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

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

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 := ;
   output sum_max_complex;
BEGIN
    RAISE NOTICE '-------------------';
    RAISE NOTICE 'IL PRIMO VALORE DI INPUT E: % ... %',.sum,.max_v;
    RAISE NOTICE 'IL SECONDO VALORE DI INPUT E: %',;
    IF  IS NOT NULL THEN
      sumValue := calculateSumAggregate(sumValue,) + sumValue;
    ELSE
      sumValue := sumValue;
    END IF;
    max_v := searchmaximumvalue(max_v,);


    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 := .max_v;
   laplaceDistribution real;
BEGIN

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

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

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

在我的 table 列中,我的值为:19、22、22.5、27。 它在第一个函数的 $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(
    .sum + coalesce(, 0),
    greatest(.max_v, )
)::sum_max_complex;
$$ LANGUAGE SQL IMMUTABLE;

CREATE OR REPLACE FUNCTION addLaplacianNoiseSum(sum_max_complex) RETURNS real AS $$
  select .sum + (.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