Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: Problem z laczeniem tabel
Forum PHP.pl > Forum > Bazy danych > MySQL
Gwozdyk
Załóżmy ze mamy dwie tabele A i B. Tabela B przechowuje czesc rekordow z tabeli A. Jak zrobic aby baza wyszukala nam tylko te rekordy ktore istnieja w tabeli A a nie istnieja w tabeli B.
Udalo mi sie zrobic rzecz odwrotna. Wyszukac z tabeli A te dane ktore istnieja w tabeli B:

Kod
select *
from tabelaA, tabelaB
where tabelaA.id = tabelaB.id


W ta strone metoda dziala, jesli zastosuje znak nierownosci wynik jest bez sensu gdyz pojawiaja sie dane bezsensowne wynikajace w laczenia tabel na zasadzie kazdy rekord z kazdym
Help winksmiley.jpg
nevt
  1. SELECT tabelaA.* FROM tabelaA LEFT JOIN tabelaB USING (id) WHERE tabelaB.id IS NULL;
Gwozdyk
Cos to nie dziala tak jak powinno.
Baza wyszukuje wszystkie przedmioty z tabeli A bez wzgledu na to czy znajduja sie w tabeli B czy nie.
nevt
pokaż strukturę tabel ...
MMPrime
Kod
SELECT * FROM tabelaA WHERE id NOT IN(SELECT id FROM tabelaB)

Wyświetli wszystkie rekordy z tabelaA których nie ma w tabelaB.
Gwozdyk
Drugi sposob dziala.
Jesli chodzi o rozwiazanie nevt'a to chyba problem jest w tym ze w tabeli B id nie jest powiazane z id z tabeli A. Id z tabeli A odzwierciedla idprzedmiotu z tabeli B
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.