Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: Konstrukcja zapytania w skrypcie ze znajomymi
Forum PHP.pl > Forum > Bazy danych > MySQL
cycofiasz
Witam, mam takie tabele: users i friends.

Tabela friends składa się z 3 pól: friendship_id,friend1,friend2.
Tabela users składa się z 2 pól: user_id i username.
Chciałbym teraz pobrać nicki wszystkich przyjaciół usera o id=1, którego id może znajdować się zarówno w polu friend2 jak i friend1.

Mam takie zapytanie :
  1. SELECT friendship_id,friend2,username FROM friends,users WHERE friend1 = 1 AND friend2=user_id
  2. UNION
  3. SELECT friendship_id,friend1,username FROM friends,users WHERE friend2 = 1 AND friend1=user_id


Ale nie jest ono zbyt wydajne (union).
Kiedyś kombinowałem z takim zapytaniem , ale nie umiem dodać do tego żeby pobierało z tabeli users pole username:

  1. SELECT friendship_id, IF( friend1 =1, friend2, friend1 ) AS przyjaciel
  2. FROM friends WHERE friend1 =1 OR friend2 =1;


Jak zmodyfikować to drugie zapytanie tak aby pobierało też username?
xmik
Tak, poza nawiasem. Mało wydajnie łączysz tabele. Użyj JOIN'ów.
SzamanGN
A gdzie widzisz problem:
  1. SELECT u.`username`
  2. FROM `users` AS u,`friends` AS f
  3. WHERE (f.`friend1`=u.`user_id` AND f.`friend2`=1) OR (f.`friend2`=u.`user_id` AND f.`friend1`=1)
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-2024 Invision Power Services, Inc.