PostgreSQL
 sql >> Datenbank >  >> RDS >> PostgreSQL

Eine Schleife in ein SQL einbauen

Das Problem besteht darin, die Funktion mit Argumenten aufzurufen, aber beim Erstellen der Funktion keine anzugeben. Sie brauchen also etwas wie (nicht getestet):

CREATE FUNCTION "UpdatePMPM"(nbr_mem_months integer, effectivdate date, some_arg varchar) RETURNS void
    LANGUAGE plpgsql
AS
$$
DECLARE
    ym varchar := to_char(effectivedate,'YYYYMM');
BEGIN
        FOR r IN  1..nbr_mem_months LOOP
            
            UPDATE elan.pmpm set mbrmonths = mbrmonths+1 where yyyyymm = ym;
            effectivedate = effectivedate + interval '1 month';
            ym=to_char(effectivedate,'YYYYMM');
        END LOOP;
    RETURN;
END
$$;

Aus dem Fehler geht nicht hervor, was das dritte Argument sein soll, daher eine Klarstellung von Ihnen.