PostgreSQL
 sql >> Baza danych >  >> RDS >> PostgreSQL

Rekurencyjna instrukcja SQL (Postgresql) - wersja uproszczona

Konfiguracja testowa:

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

Uruchom INSERT w PĘTLI z 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;
$$

Zobacz wynik:

SELECT * FROM matrix order BY 1,2;


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Funkcja okna PostgreSQL:row_number() over (kolejność partycji wg col2)

  2. psycopg2 i zabezpieczenia wstrzykiwania SQL

  3. postgresql:INSERT INTO ... (WYBIERZ * ...)

  4. Czy XPath sum lub funkcja fn:sum jest zaimplementowana w PostgreSQL XPath?

  5. Tablica zapytań dla pętli `for await` dla pomocnika transakcji postgresql