Subquery’s en common table expressions (cte)

Queryprestaties verbeteren in PostgreSQL

Amy McCarty

Instructor

Over subquery’s

Wat?

  • Alternatief voor join
  • Eenvoudige query

Waarom?

  • Kan één resultaat geven
  • Leesbaar
  • SQL-instructies vergelijkbaar met joins

Hoe?

  • In SELECT-, FROM- of WHERE-clausules
Queryprestaties verbeteren in PostgreSQL

SELECT-subquery

rij script_word word_length
1 goat 4
2 goat 4
3 dog 3
15,782 ... ...
rij english_word word_length
1 goat 4
2 turkey 6
3 ant 3
171,476 ... ...
Queryprestaties verbeteren in PostgreSQL

SELECT-subquery

SELECT AVG(word_length) AS avg_movie
  , (SELECT AVG(word_length) 
      FROM english_language) 
      AS avg_english
FROM MOVIE
avg_movie avg_english
3 4.5
Queryprestaties verbeteren in PostgreSQL

WHERE-subquery

rij script_word word_length
1 goat 4
2 goat 4
3 dog 3
15,782 ... ...
rij english_word word_length
1 goat 4
2 turkey 6
3 ant 3
171,476 ... ...
Queryprestaties verbeteren in PostgreSQL

WHERE-subquery

SELECT AVG(word_length) AS avg_movie
FROM english_language
WHERE word IN 
  (SELECT DISTINCT word FROM movie) 
avg_movie
3
Queryprestaties verbeteren in PostgreSQL

FROM-subquery

SELECT AVG(word_length) AS avg_movie 
FROM (SELECT * FROM movie)

 

  • Minder leesbaar
  • Minder flexibiliteit in queryplan
Queryprestaties verbeteren in PostgreSQL

Over common table expressions (CTE’s)

Wat?

  • Alternatief voor join
  • Losse query met tijdelijke resultaten

Waarom?

  • Kan één resultaat geven
  • Leesbaar
  • Maakt een tijdelijke tabel

Hoe?

  • WITH-statements
Queryprestaties verbeteren in PostgreSQL

CTE-structuur

WITH english_cte AS
(    
  SELECT word_length
      , COUNT(word) AS english_word_count
    FROM english_language 
    GROUP BY word_length
)

SELECT movie.word_length , COUNT(movie.word) AS movie_word_count , cte.english_word_count FROM movie INNER JOIN english_cte cte ON movie.word_length = cte.word_length GROUP BY movie.word_length, cte.english_word_count
Queryprestaties verbeteren in PostgreSQL

Laten we oefenen!

Queryprestaties verbeteren in PostgreSQL

Preparing Video For Download...