Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> Select w select czy join-y
marcio
post
Post #1





Grupa: Zarejestrowani
Postów: 2 291
Pomógł: 156
Dołączył: 23.09.2007
Skąd: ITALY-MILAN

Ostrzeżenie: (10%)
X----


Czesc nie znam sie bardzo na bazach danych i chcialem sie zapytac powiedzmy ze musze pobrac dane z 3 tabel users,ban i active_account i nawet gdy nie znajdzie rekordu w ktorejs z tabel to ma zwrocic null czyli w tym przypadku uzywajac relacje musze uzyc LEFT JOIN

I problem polega na tym lepiej jest wykonywac takie zapytania w ten sposob:
  1. SELECT *
  2. FROM users
  3. LEFT JOIN ban ON ban_user = users.login
  4. LEFT JOIN active_account ON active_user_id = users.id
  5. WHERE login = 'vodka'
  6. LIMIT 1

Czy:
  1. SELECT * , (
  2. SELECT id
  3. FROM ban
  4. WHERE ban_user = 'vodka'
  5. ) AS banned , (
  6. SELECT id
  7. FROM active_account
  8. WHERE active_user_id = users.id
  9. ) AS active
  10. FROM users
  11. WHERE login = 'vodka'
  12. LIMIT 1

Ktore zapytanie jest bardziej wydajne?
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi
skowron-line
post
Post #2





Grupa: Zarejestrowani
Postów: 4 340
Pomógł: 542
Dołączył: 15.01.2006
Skąd: Olsztyn/Warszawa

Ostrzeżenie: (0%)
-----


Należy też przypomnieć że używając podzapytań w select jesteśmy w stanie wydobyć tylko jedną kolumnę.

Ten post edytował skowron-line 23.04.2012, 12:08:13
Go to the top of the page
+Quote Post

Posty w temacie


Reply to this topicStart new topic
2 Użytkowników czyta ten temat (2 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Aktualny czas: 10.10.2025 - 02:54