On Wed, Jun 24, 2015 at 12:54 PM, Seb <splu...@gmail.com> wrote:

> Hello,
>
> I've defined a function to calculate standard deviation of angular
> values:
>
> CREATE AGGREGATE public.stddev(angle_vectors) (
>   SFUNC=array_append,
>   STYPE=angle_vectors[],
>   FINALFUNC=angle_vectors_stddev_yamartino
> );
>
> The type angle_vectors is simply an array:
>
> CREATE TYPE public.angle_vectors AS
>    (x double precision,
>     y double precision);
> COMMENT ON TYPE public.angle_vectors
>   IS 'This type holds the x (sine) and y (cosine) components of angle(s).';
>
> How can I protect this function so that NULL is returned whenever *all*
> input rows are NULL?
>
> Thanks for any feedback,
>

​Going from memory here...​

​You don't "protect" anything.  angle_vectors_stddev_yamartino needs to
check whether its input array only contains null and, if so, return null.

AFAIK there is no built-in way to check for only-null since "null =
ALL(...)" doesn't work and you cannot say "IS NULL ALL(...)"

In a simple case you could do something like:

SELECT array_to_string(ARRAY[null,null]::integer[],'') = ''

​Not sure how that translates when using a composite type...and there is a
difference between a non-null type with null components and a nulled type.

David J.​

Reply via email to