sql >> Database teknologi >  >> RDS >> PostgreSQL

Rekursiv SQL-sætning (Postgresql) - forenklet version

Testopsætning:

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

Kør INSERT'er i en LOOP med 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;
$$

Se resultat:

SELECT * FROM matrix order BY 1,2;


  1. Hvor gemmer Android SQLites databaseversion?

  2. Android - opdater klientens sqlite-database ved hjælp af GCM

  3. Konverter SQL-resultater til PHP-array

  4. Sådan indstilles MariaDB til at bruge vertikalt output