Słowo kluczowe MySQL CROSS JOIN
Słowo kluczowe SQL CROSS JOIN
Słowo CROSS JOIN
kluczowe zwraca wszystkie rekordy z obu tabel (tabela1 i tabela2).
CROSS JOIN Składnia
SELECT column_name(s)
FROM table1
CROSS JOIN table2;
Uwaga: CROSS JOIN
może potencjalnie zwrócić bardzo duże zestawy wyników!
Demo bazy danych
W tym samouczku użyjemy dobrze znanej przykładowej bazy danych Northwind.
Poniżej wybór z tabeli „Klienci”:
CustomerID | CustomerName | ContactName | Address | City | PostalCode | Country |
---|---|---|---|---|---|---|
1 |
Alfreds Futterkiste | Maria Anders | Obere Str. 57 | Berlin | 12209 | Germany |
2 | Ana Trujillo Emparedados y helados | Ana Trujillo | Avda. de la Constitución 2222 | México D.F. | 05021 | Mexico |
3 | Antonio Moreno Taquería | Antonio Moreno | Mataderos 2312 | México D.F. | 05023 | Mexico |
Oraz wybór z tabeli „Zamówienia”:
OrderID | CustomerID | EmployeeID | OrderDate | ShipperID |
---|---|---|---|---|
10308 | 2 | 7 | 1996-09-18 | 3 |
10309 | 37 | 3 | 1996-09-19 | 1 |
10310 | 77 | 8 | 1996-09-20 | 2 |
Przykład MySQL CROSS JOIN
Poniższa instrukcja SQL wybiera wszystkich klientów i wszystkie zamówienia:
Przykład
SELECT Customers.CustomerName, Orders.OrderID
FROM Customers
CROSS JOIN Orders;
Uwaga: słowo CROSS JOIN
kluczowe zwraca wszystkie pasujące rekordy z obu tabel, niezależnie od tego, czy druga tabela jest zgodna, czy nie. Tak więc, jeśli istnieją wiersze w „Klienci”, które nie mają dopasowań w „Zamówieniach” lub jeśli istnieją wiersze w „Zamówieniach”, które nie mają dopasowań w „Klienci”, te wiersze również zostaną wyświetlone.
Jeśli dodasz WHERE
klauzulę (jeśli table1 i table2 są ze sobą powiązane), CROSS JOIN
da taki sam wynik jak INNER JOIN
klauzula:
Przykład
SELECT Customers.CustomerName, Orders.OrderID
FROM Customers
CROSS JOIN Orders
WHERE Customers.CustomerID=Orders.CustomerID;