Felles tabelluttrykk

en navngitt (fullt kvalifisert) midlertidig resultattabell (resultatmengde) utledet fra en enkel spørring og definert innenfor det uførende virkefeltetet til et SELECT, INSERT, UPDATE eller DELETE -uttrykk

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

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

Syntaks rediger

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

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

  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.