Farklı veri ayrıntı düzeylerinde toplama

PostgreSQL'de Sorgu Performansını İyileştirme

Amy McCarty

Instructor

Veri ayrıntı düzeyi - detay seviyesi

 

  • Bir satırı benzersiz kılar
  • 1+ sütun

 

Video_Games

id game first_yr
012 Grand Theft Auto 1997
234 Legend of Zelda 1986

 

 

 

Game_Platforms

game_id platform year
234 FCDS 1986
234 GameCube 2003
234 Wii 2006
PostgreSQL'de Sorgu Performansını İyileştirme

Farklı ayrıntı düzeylerini birleştirme

Video_Games tablosundaki The Legend of Zelda kaydı, Games_Platforms tablosundaki 3 kaydın tümüne bağlanır.

SELECT g.id, g.game, g.first_yr
  , COUNT(p.platform) AS no_platforms
  , MAX(p.year) AS last_platform_yr
  , p.platform
FROM video_games g
INNER JOIN game_platforms p
  ON g.id = p.game_id
GROUP BY g.id, g.game, g.first_yr
, p.platform
PostgreSQL'de Sorgu Performansını İyileştirme

Farklı ayrıntı düzeylerini birleştirme

 

Çıktı

id game first_yr no_platforms last_platform_yr platform
234 Legend of Zelda 1986 3 2006 FCDS
234 Legend of Zelda 1986 3 2006 GameCube
234 Legend of Zelda 1986 3 2006 Wii
PostgreSQL'de Sorgu Performansını İyileştirme

Ayrıntı düzeyi değişikliğini hazırlama

 

Game_Platforms

game_id platform year
234 FCDS 1986
234 GameCube 2003
234 Wii 2006

 

PostgreSQL'de Sorgu Performansını İyileştirme

Ayrıntı düzeyi değişikliğini hazırlama

SELECT game_id, platform, year
  , COUNT(platform) AS no_platforms
  , MAX(year) AS last_platform_yr
FROM game_platforms
GROUP BY game_id, platform, year

Çıktı

game_id platform year no_platforms last_platform_yr
234 FCDS 1986 3 2006
234 GameCube 2003 3 2006
234 Wii 2006 3 2006
PostgreSQL'de Sorgu Performansını İyileştirme

CTE’lere yeniden bakış

  • Geçici sonuç kümesi olan bağımsız sorgu
  • WITH deyimi
WITH cte AS
  ( SELECT * FROM tableA )

SELECT * FROM cte
  • Birleştirmeden önce toplamaya izin verir
PostgreSQL'de Sorgu Performansını İyileştirme

CTE’ler imdada yetişiyor

WITH platforms_cte AS 
(  SELECT game_id, platform, year
      , COUNT(platform) AS no_platforms
      , MAX(year) AS last_platform_yr
   FROM game_platforms
   GROUP BY game_id, platform, year )
SELECT g.id, g.game, cte.no_platforms
  , cte.platform AS last_platform
FROM video_games g
INNER JOIN platforms_cte cte 
  ON g.id = cte.game_id
  AND cte.last_platform_yr = cte.year
PostgreSQL'de Sorgu Performansını İyileştirme

CTE’ler imdada yetişiyor

WITH platforms_cte AS 
(  SELECT game_id, platform, year
      , COUNT(platform) AS no_platforms
      , MAX(year) AS last_platform_yr
   FROM game_platforms
   GROUP BY game_id, platform, year )
SELECT g.id, g.game, cte.no_platforms
  , cte.platform AS last_platform
FROM video_games g
INNER JOIN platforms_cte cte 
  ON g.id = cte.game_id
  AND cte.last_platform_yr = cte.year

Çıktı

id game no_platforms last_platform
234 Legend of Zelda 3 Wii
PostgreSQL'de Sorgu Performansını İyileştirme

Birleştirirken ayrıntı düzeyini eşleştirme

 

  • Tekrar veya kopya yok
  • Gerekli en az sonuç
  • Çifte sayım yok
PostgreSQL'de Sorgu Performansını İyileştirme

Hadi pratik yapalım!

PostgreSQL'de Sorgu Performansını İyileştirme

Preparing Video For Download...