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 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.