Verwendung von „Join“ (Verbund) in Snowflake

Einführung in Snowflake SQL

George Boorman

Senior Curriculum Manager, DataCamp

JOINS

  • INNER JOIN
  • OUTER JOINS
    • LEFT OUTER oder JOIN LEFT?
    • RIGHT OUTER oder JOIN RIGHT?
    • FULL OUTER oder JOIN FULL?
  • CROSS JOINS
  • SELF JOINS
  • NATURAL JOIN
  • LATERAL JOIN
Einführung in Snowflake SQL

Pizza-Datensatz

Schema-Diagramm der Pizza-Datenbank

Einführung in Snowflake SQL

NATURAL JOIN

  • NATURAL JOIN Spalten automatisch abgleichen und doppelte Spalten löschen

Syntax

SELECT ...
FROM <table_one> [
                     {
                       | NATURAL [ { LEFT | RIGHT | FULL } [ OUTER ] ]
                     }
                   ]
                   JOIN <table_two>
[ ... ]
Einführung in Snowflake SQL

NATURAL JOIN

Ohne NATURAL JOIN

SELECT * 
FROM pizzas AS p 
JOIN  pizza_type AS t 
    ON t.pizza_type_id = p.pizza_type_id

Ergebnis ohne natürliche Verknüpfung

NATURAL JOIN mit

SELECT *
FROM pizzas AS p 
NATURAL JOIN pizza_type AS t

  Ergebnis mit natürlicher Verknüpfung verbinden

Einführung in Snowflake SQL

NATURAL JOIN

 

NOT ALLOWED

select *
FROM pizzas AS p 
NATURAL JOIN pizza_type AS t
    ON  t.pizza_type_id = p.pizza_type_id

Syntaxfehler-Bild

Einführung in Snowflake SQL

NATURAL JOIN

$$

ERLAUBT

  • WHERE Klausel
SELECT *
FROM pizzas AS p 
NATURAL JOIN pizza_type AS t
WHERE pizza_type_id = 'bbq_ckn'
Einführung in Snowflake SQL

LATERAL JOIN

  • LATERAL JOINLässt eine Unterabfrage in „ FROM “ Spalten aus vorhergehenden Tabellen oder Ansichten referenzieren.

Syntax

SELECT ...
FROM <left_hand_expression> , -- 
LATERAL 
(<right_hand_expression>)

  • left_hand_expression - Tabelle, Ansicht oder Unterabfrage

  • right_hand_expression - Inline-Ansicht oder Unterabfrage

Einführung in Snowflake SQL

LATERAL JOIN mit einer Unterabfrage

SELECT 
    p.pizza_id, 
    lat.name, 
    lat.category 
FROM pizzas AS p,

LATERAL -- Keyword LATERAL ( SELECT * FROM pizza_type AS t
-- Referencing outer query column: p.pizza_type_id WHERE p.pizza_type_id = t.pizza_type_id
) AS lat
Einführung in Snowflake SQL

Warum?

SELECT 
    *
FROM orders AS o,
LATERAL (
   -- Subquery calculating total_spent
    SELECT 
        SUM(p.price * od.quantity) AS total_spent
    FROM order_details AS od
    JOIN pizzas AS p 
          ON od.pizza_id = p.pizza_id
    WHERE o.order_id = od.order_id
) AS t
ORDER BY o.order_id
Einführung in Snowflake SQL

Lass uns üben!

Einführung in Snowflake SQL

Preparing Video For Download...