SQL CROSS JOIN – Kartézský součin

Příkaz CROSS JOIN v SQL souží ke spojení 2 tabulek v relační databázi. Jeho výsledkem je kartézský součin => všechny kombinace levé (A) a pravé (B) tabulky.

SQL CROSS JOIN

Logika

Syntaxe:

SELECT sloupce
FROM Tabulka_A CROSS JOIN Tabulka_B

/*Tabulka A = levá; Tabulka B = pravá*/

Příklad CROSS JOIN:

Tento typ JOINu si můžeme ukázat na příkladu. Vyrobíme si 2 tabulky jako na obrázku výše a následně na ně aplikujeme tento typ joinu:

/*Vytvoríme obe tabulky*/
CREATE TABLE Prvni_tabulka (ID INT IDENTITY(1,1), Hodnota_z_Prvni_tabulky VARCHAR(100));
CREATE TABLE Druha_tabulka (ID INT IDENTITY(1,1), Hodnota_z_druhe_tabulky VARCHAR(100));

/*Naplníme tabulky*/
INSERT INTO Prvni_tabulka (Hodnota_z_Prvni_tabulky)
VALUES ('Jedna'), ('Dve');

INSERT INTO Druha_tabulka (Hodnota_z_druhe_tabulky)
VALUES ('Jedna'), ('Dve'), ('Tri'), ('Ctyri'), ('Pet');

/*Výsledný skript*/
SELECT *
FROM Prvni_tabulka
CROSS JOIN Druha_tabulka;

Výsledkem je kartézský součin “každý s každým” a proto budeme očekávat 10 záznamů (2*5 záznamů):

Vysledek-CROSS-JOIN

Výsledek




Rate this post
Rubrika: Základy SQL

O Ing. Jan Zedníček - Data Engineer & Controlling

Jmenuji se Honza Zedníček a působím jako data engineer freelancer. Během cca 10 let jsem zde shromáždil přes 600 IT case studies, průvodců, návodů a tipů určených zejména odborné veřejnosti, studentům a zájemcům o informace z oblastí Data Engineeringu, korporátních financí a reportingu. Zaměřuji se především na Microsoft technologie (on-prem i cloud) a různé synergické efekty v rámci jejich produktového portfolia pro dataře a finanční profesionály. Věnuji se také dalším platformám a významným hráčům z oblasti open source technologií. 🔥 Pokud vám tento článek pomohl, ocením referenci na vašem webu nebo zmínku v komunitě. A mám pro vás ještě tip: řešíte-li nějaký zapeklitý Excel problém, přihlašte se do naší Excel Facebook skupiny (2.4k+ členů), kde si pomáháme Excel CZ/SK diskuse ».

3 thoughts on “SQL CROSS JOIN – Kartézský součin

  1. sup

    SELECT sloupce
    FROM Tabulka_A CROSS JOIN Tabulka_B
    ON TabulkaA.sloupec=TabulkaB.sloupec

    jste si jist tim poslednim radkem? dle meho cross join provede kartezky soucin vsech zaznamu, bez ohledu na hodnoty a radek ktery by specifikoval sloupce pro soucin se nepouziva

      1. Kuba

        Tohle bylo první, co jsem udělal, když jsem se CROSS JOIN učil 🙂 … ON col1 = col2

Leave a Reply

Your email address will not be published. Required fields are marked *