sql >> Database >  >> RDS >> PostgreSQL

Recursieve SQL-instructie (Postgresql) - vereenvoudigde versie

Testopstelling:

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);

Voer INSERT's uit in een LOOP met 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;
$$

Zie resultaat:

SELECT * FROM matrix order BY 1,2;


  1. Ontbrekende juiste Paranthesis bij Create Table-opdracht SQL

  2. MySQL-fout:sleutelspecificatie zonder sleutellengte

  3. Oracle High Availability-concepten in PostgreSQL

  4. een html-pagina crawlen met php?