Felles tabelluttrykk

Fra Wikipedia, den frie encyklopedi

Et felles tabelluttrykk[1] (CTE, common table expression) i SQL-databaser er et uttrykk som definerer en resultattabell med et navn, og er et alternativ til delspørringer, visninger og brukerdefinerte funksjoner.

En CTE gir en navngitt resultatmengde som eksisterer midlertidig, utledet fra en enkel spørring og definert under kjøringen av et SELECT, INSERT, UPDATE eller DELETE-uttrykk, og bare for bruk innenfor en større (ytre?[klargjør]) spørring. Det er et kraftig verkøy i SQL som kan forenkle en spørringer ved at de kan deles i mindre komponenter. De gjør det mulig å referere til en spørring flere ganger uten å gjenta kode. Siden CTE-er er navngitte kan de gjøre det lettere for leseren hva et uttrykk er ment å returnere. En CTE lagrer resultatet midlertidig i minnet slik at det kan brukes av spørringer som refererer til den.[2]

Støtte[rediger | rediger kilde]

Felles tabelluttrykk støttes av blant annet databasene DB2, Firebird, Microsoft SQL Server, Oracle og PostgreSQL.

Syntaks[rediger | rediger kilde]

Syntaksen for et felles tabelluttrykk er på formen:

WITH [RECURSIVE] expression_with [, ...]
SELECT...

hvor expression_with skal være:

identification_name [ (column_name [,...]) ] AS (SELECT ...)

Semikolon[rediger | rediger kilde]

Det er veldig vanlig å starte et felles tabelluttrykk med et semikolon, altså

;WITH ...

, ettersom WITH kan brukes i andre typer uttrykk (eksempelvis

; ... FROM ... WITH (NOLOCK) ...

eller

; RESTORE ... WITH MOVE ...

), samt at semikolon er valgfritt i Microsoft SQL Server.

Referanser[rediger | rediger kilde]

  1. ^ «DB2-ordliste». www.ibm.com (norsk). Besøkt 19. mai 2023. 
  2. ^ Myrianthous, Giorgos (28. november 2022). «What are CTEs in SQL». Medium (engelsk). Besøkt 22. mai 2023.