Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: Iloczyn kartezjański czy Join
Forum PHP.pl > Forum > Bazy danych > MySQL
henio
Zapewne tego typu pytanie było stawiane wielokrotnie. Jednakże, ostatnio szukając w necie na ten temat napotykałem się na sprzeczne stwierdzenia. Chciałbym więc dowiedzieć się jak to jest, co jest bardziej wydajne - iloczyn kartezjański czy stosowanie Join.
maly_swd
z tego co dobrze pamietam to JOIN to sposob laczenia a ILOCZYN KARTEZJANSKI to wynik laczenia..

dr_bonzo
Cytat
z tego co dobrze pamietam to JOIN to sposob laczenia a ILOCZYN KARTEZJANSKI to wynik laczenia..

Tak, o ile nie wprowadzimy ograniczen zlaczenia ( ON a.bbb = b.id ) itp. to otrzymamy Il Kart. - czyli polaczony kazdy rekord z kazdym.

I wlasciwie nie da sie powiedziec co jest szybsze bo I K zadko kiedy potrzebujesz i w 99% chcesz uzyc joina.
andycole
Wg mnie zdecydowanie JOIN jest szybszy.

Ostatnio robilem testy (oczywiscie mialem tam rozne klauzule WHERE) i zastosowanie:

  1. FROM tabela1 LEFT JOIN tabela2 ON tabela1.pole1=tabela2.pole2


bylo o wiele lepsze (wniosek na podstawie funkcji EXPLAIN) niz:

  1. FROM tabela1, tabela2 (+ dodatkowy WHERE okreslajacy sposob powiazania tych 2 tabel)
To jest wersja lo-fi głównej zawartości. Aby zobaczyć pełną wersję z większą zawartością, obrazkami i formatowaniem proszę kliknij tutaj.
Invision Power Board © 2001-2025 Invision Power Services, Inc.