• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

SQL łączenie tabel i wykorzystanie exists

VPS Starter Arubacloud
0 głosów
434 wizyt
pytanie zadane 12 marca 2023 w SQL, bazy danych przez Blds Użytkownik (830 p.)

Potrzebuję wyciągnąć customer i email z tabeli customer, ale tylko tych klientów których adres zamieszkania jest inny niż PL - ta informacja jest zapisana w tabeli order_address, która łączy się z tabelą customer przez tabelę pomostową order . Wymyśliłem dwie wariacje zapytania z exists. Które z nich jest poprawne, a może oba są?

1. SELECT customer_id, email
FROM customer
WHERE EXISTS (
                              SELECT 1 
                              FROM order as o
                              INENR JOIN customer as c on c.customer_id = o.customer_id
                              INNER JOIN order_address as oa on oa.order_id = o.order_id
                              WHERE country_code != 'PL'
                            )
2. SELECT customer_id, email
FROM customer as c
INNER JOIN order as o on c.customer_id = o.customer_id 
WHERE EXISTS (
                              SELECT 1 
                              FROM order_address as oa
                              WHERE oa.order_id = o.order.id
                             AND country_code != 'PL'
                            )

 

komentarz 13 marca 2023 przez PreZmyK Pasjonat (21,470 p.)
Jeżeli nie skorelujesz podzapytania, to on Ci zwróci prawdę dla całego zapytania jak znajdzie jakikolwiek record i fałsz jeżeli nie znajdzie.

1 odpowiedź

0 głosów
odpowiedź 12 marca 2023 przez Wiciorny Ekspert (269,120 p.)

Pierwsze zapytanie wydaje się być poprawne, po za faktem, że taki sposób pisania SQL jest bardzo nieczytelny...

Literówka tam jedna jest zamiast INENR powinno być INNER
 

 INENR JOIN customer as c on c.customer_id = o.customer_id

czy jesteś pewny że potrzebujesz wyniki złączenia danych z tej tabeli ? gdyż otrzymasz również zestawy wszystkich wyników dla których złączenie jest prawdziwe. 
Natomiast Twoje zapytanie 2  jest także  poprawne i działa tak samo jak poprzednie zapytanie.

Oba są jakby poprawne, i efektywne natomiast różnice mogą zależeć od struktury bazy danych.

Też istnieje subtelna różnica w optymalizacji pomiędzy tymi zapytaniami... ale też to zalezy od rodzaju bazy danych, ilości danych, powiązań czy indeksów. 

komentarz 12 marca 2023 przez Blds Użytkownik (830 p.)

Co to znaczy, że taki sposób pisania SQL jest bardzo nieczytelny. Czy jest jakiś inny sposób na rozpisanie tego?

 INNER JOIN customer as c on c.customer_id = o.customer_id

potrzebuję połączyć tabelę customer z order_address, a tabela order jest pomostową więc chyba nie mam wyboru

Podobne pytania

0 głosów
0 odpowiedzi 160 wizyt
pytanie zadane 17 października 2019 w SQL, bazy danych przez Alan Kruszyński Obywatel (1,410 p.)
0 głosów
2 odpowiedzi 606 wizyt
pytanie zadane 7 marca 2019 w SQL, bazy danych przez hiper007 Stary wyjadacz (11,270 p.)
+1 głos
1 odpowiedź 298 wizyt
pytanie zadane 14 kwietnia 2023 w SQL, bazy danych przez Blds Użytkownik (830 p.)

92,453 zapytań

141,262 odpowiedzi

319,087 komentarzy

61,854 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Akademia Sekuraka 2024 zapewnia dostęp do minimum 15 szkoleń online z bezpieczeństwa IT oraz dostęp także do materiałów z edycji Sekurak Academy z roku 2023!

Przy zakupie możecie skorzystać z kodu: pasja-akademia - użyjcie go w koszyku, a uzyskacie rabat -30% na bilety w wersji "Standard"! Więcej informacji na temat akademii 2024 znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...