sql >> Databáze >  >> RDS >> PostgreSQL

Rekurzivní SQL příkaz (Postgresql) - zjednodušená verze

Testovací nastavení:

CREATE TEMP TABLE matrix (
    rowindex integer,
    columnindex integer,
    matrixvalue numeric);

INSERT INTO matrix VALUES
 (1,1,2),(1,2,2),(1,3,3),(1,4,3),(1,5,4)
,(2,1,4),(2,2,4),(2,3,5),(2,4,6)
,(3,1,3),(3,2,2),(3,3,2)
,(4,1,2),(4,2,1)
,(5,1,1);

Spusťte INSERT ve smyčce pomocí DO :

DO $$
BEGIN

FOR i IN 2 .. 5 LOOP
   FOR j IN 7-i .. 5 LOOP
      INSERT INTO matrix
      VALUES (i,j, (
         SELECT sum(matrixvalue)/2
         FROM   matrix
         WHERE  (rowindex, columnindex) IN ((i-1, j),(i, j-1))
         ));
   END LOOP;
END LOOP;

END;
$$

Viz výsledek:

SELECT * FROM matrix order BY 1,2;


  1. min(sloupec) mi nevrací správná data jiných sloupců

  2. TNS-12519 bez dosažení maximálního počtu procesů

  3. Kolejnice rozšiřující pole s rozsahem, to se PG nelíbí

  4. Jak zjistit věk v letech, měsících a dnech pomocí Oracle