Uso delle CTE con Redshift

Introduzione a Redshift

Jason Myers

Principal Architect

Common Table Expressions (CTE)

  • Set di risultati temporaneo
  • Semplificano le query
  • Alternativa alle subquery
Introduzione a Redshift

Strutture: subquery e CTE

SELECT division_name,
       revenue_total
       -- Subquery for top 10 divions by revenue
  FROM (SELECT division_id,
               SUM(revenue) AS revenue_total
          FROM orders
         GROUP BY division_id
         ORDER BY revenue_total DESC
         LIMIT 10) top_ten_divisions_by_rev
 WHERE revenue_total > 100000; 
-- CTE for top 10 divions by revenue
WITH top_ten_divisions_by_rev AS (
  SELECT division_id,
         SUM(revenue) AS revenue_total
    FROM orders
   GROUP BY division_id
   ORDER BY revenue_total DESC
   LIMIT 10)

-- Main query SELECT division_id, revenue_total -- FROM our CTE FROM top_ten_divisions_by_rev WHERE revenue_total > 100000;
Introduzione a Redshift

CTE multiple

-- Top 10 divisions by revenue CTE
WITH top_ten_divisions_by_rev AS(
  SELECT division_id,
         SUM(revenue) AS revenue_total
    FROM orders
   GROUP BY division_id
   ORDER BY revenue_total DESC
   LIMIT 10),

-- Division ID and Name CTE division_names AS( SELECT id AS division_id, name AS division_name FROM divisions)
-- Main query
SELECT division_name,
       revenue_total
       -- FROM Top 10 CTE
  FROM top_ten_divisions_by_rev
  -- Joining so we can use the division name
  JOIN division_names USING (DIVISION_ID)
 WHERE revenue_total > 100000;
Introduzione a Redshift

CTE multiple, join tra CTE

-- Selecting the division names
WITH division_names AS(
  SELECT id AS division_id,
         name AS division_name
    FROM divisions),
-- Selecting the top ten divisions by revenue
top_ten_divisions_by_rev AS(
  SELECT division_name,
         SUM(revenue) AS revenue_total
    FROM orders
    -- Joining in the division_names CTE
    JOIN divisions USING (division_id)
   GROUP BY division_name
   ORDER BY revenue_total DESC
   LIMIT 10);

Legge di Kernighan

Tutti sanno che il debug è due volte più difficile che scrivere un programma. Quindi, se sei il più brillante possibile quando lo scrivi, come farai mai a fare debug?

Introduzione a Redshift

Prestazioni delle CTE

  • Uguali alle subquery
  • Migliori se riutilizzate

Codice SQL vs Ordine di esecuzione

Introduzione a Redshift

Passons à la pratique !

Introduzione a Redshift

Preparing Video For Download...